الأوراكل 
ORACLE?‏ 


نتعرض في هذا الفصل الى مقدمة في ادارة قواعد البيانات مووطواو وخاصة قواعد بيانات 
الأوراكل والذي يعتبر أحد النظم القوية في قواعد البيانات Data Base Management‏ 
System (DBMS)‏ لماله من مميزات مقارنة بقواعد البيانات الاخرى . 


مفاهيم قواعد البيانات 


قاعدة البيانات seئوط Data‏ 
هي مجموعه من الملفات المنظمة بحيث يسهل الوصول إليها عندمت نريد استردادها 


تمو lبilıٽ Data Dictionary‏ 
نظام إدارة قواعد البيانات 


الاستعلام Query‏ 
هو نظام استفساري للاستعلام عن بيانات معينة وغاليا لا يغير الاستعلام في قاعدة البيانات حيث 
إن غالبية نظم الاستعلام عبارة عن قراءة فقط للبيانات 


llدJIg Function‏ 
عبارة عن مجموعة من تعليما ت أو أوامر تستخدم ضمن مسمى وظيفي لاداء عملية محددة 
وغالبا تعيد الدالة قيمة معينه بعد تنفيذها 


الiجرlء Procedure‏ 
مجمو عة من التعليمات مثل تعليمات الدالة بهدف تنفيذ مهمة محددة لكن الاجراء لا يعيد قيمة 
مثل الدالة 


مخط¦طط Schema‏ 
عبارة عن مجمو عة من الكائنات وء زط0 مرتبطة بقواعد البيانات ويتألف مخطط 
Schema‏ من كائنات مثل الجداول وع1[طھ ۲ والاجراءات ۴roced ue‏ والعروض Views‏ 

والفهارس ×عل,1 


مدير قواعد llبlنlٽت Database Administrator (DBA)‏ 
هو الشخص المسؤؤل عن عمليات إدارة قواعد البيانات ونظم أداء هذه القواعد وكيف يتم 
تكوينها وهو مسوؤل أيضا عن مراقبة أداء هذه القواعد » وكذلك إجراء عمليات النسخ الاحتياطي 

تثبيت البرامج » والمحافظة على أمن المعلومات › وإضافة مستخدمين جدد أو إلغاء صلاحيات 


ويمكن ان يقوم مدير قواعد البيانات بالتخطيط لتطوير وتنمية النظام المطبق › وتحديد 
الحاجه لهذه التطورات المستقبلية . 


ويسعى فريق العمل الذي يتكون من مديري قواعد البيانات 84۸( للحفاظ على سير العمل داخل 
الشركة بشكل متجانس . وتتم تجزئة المهام بين هؤلاء المديرين . 


مهام مدير قواعد البیانات (08۸) 
تتباين مهام مدير قاعدة البيانات تبعا لحجم الشركة أو المؤسسة وتبعا لفريق 
العمل المساعد وتشمل هذه المهام النقاط التالية : 


۲ إدارة الحماية لنظام قواعد البيانات 

۳- النسخ الاحتياطي والدوري للبيانات ونظام قواعد البيانات 
-٤‏ استكشاف الأخطاء ومعالجتها 

-٥‏ تسوية وإصلاح إخفاقات المستخدمين للوصول إلى بياناتهم 
٦‏ متابعة ضبط أداء العمل 

۷- تقسيم الأجهزة والنظم الجديدة 

۸ العمل على تطوير النظام بالشركة 


Data Base Management System (DBMS) تٽlنlبll نظام إدارة قاع‎ 


هو عبارة عن مجموعة الأدوات البرمجيه ( البرامج ) التي تدير وتنظم قاعدة البيانات وتوجد 
علاقة ارتباط بين هذه البيانات تسمى علاقة (و10†ه[ه8) لذا احيانا يطلق عليها ۸58۸S‏ أي 
نظام إدارة قواعد البيانات العلائقية ( الارتباطية ) 


زات نظام إدارة قاعدة البيانات أوراكل 
ممیر م َء 5 e‏ ور 


يتميز نظام قاعدة البيانات أوراكل عن غيره من نظم إدارة قواعد البيانات الأخرى بالآتي: 

-١‏ القدرة الفائقة على استيعاب كميات كبيرة من البيانات قد يصل عدد السجلات إلى 
الملايين مع الحفاظ على المستوى العالي في الأداء والسرعة عند استرجاع والتخزين 
والحذف 

۲ السرية التامة والأمن لا حتوائه على نظام الصلاحيات والحقوق الذي يضمن تطبيق 
الشروط القياسية والأمنية للحفاظ على قاعدة البيانات 

۳- فعالية التحكم المركزي بالبيانات الذي يضمن : 

تقليل التكررات غير اللازمة في البيانات ائمدخlلة (No Repetition)‏ 

تجنب التناقض بين llبيlنlٽ (No Contradiction)‏ 

إمكانية التشارك في البيانات (عہS!21؟S (Data‏ 

(Data Integrity) iı nı الحفاظ على تكامل البيانات‎ 

-٤‏ السيطرة التامة على عملية النسخ الاحتياطي لقاعدة البيانات وحمايتها من الفقدان أو 
التلف مع امكانية استرجاعها في أي لحظة 
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عمليات نظام إدارة قاعدة البيانات 

قل ظا ار فا غد انات ارز اكل على العطات اة 

Data Definition Language (DDL) ٽlilıبll أوامر لغة تعريف‎ ١ 
ويمكن أن يكون الكائن ملفات‎ ٠ تستخدم هذه اللغة في تعريف وإنشاء الكائن ٤ءء زط0‎ 
وجداول بیانات ¢ فی فبمکننا انشاء وتعديل وحذف الكائن ول بمکننا انشاء امتیاز لمستخدم‎ 
معين » أو انشاء كائن خيارات لفحص وإضافة تعليقات إلى قاموس البيانات ومن هذه‎ 
CREAT , DROP and ALTER : رمlاوألا‎ 

Data Manipulation Language (DML) أوامر لغة معاملة أبنت‎ ۲ 


تتیح م التعامل مع البيانات وتعديلها ضمن الكائن الموجود زا0 ومن هذه 
الٺوlمر‏ : SELECT, DELETE,UPDATE and INSERT‏ 


۳- أوامر لغة التحكم في llبIilٽ Data Control Language (DCL)‏ 
تتيح هذه الأوامر التحكم في قاعدة البيانات وأدائها كالصلاحيات والمستخدمين والحقوق 


وغالبا ماتكون هذه الأوامر مخصصة للاستخدام من قبل مدير قاعدة البيانات (508۸) 
ومن هذ الٺوامر : GRANT and REVOKE‏ 
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التركيب الداخلي لنظام أوراكل 
أهداف الفصل 


يتناول هذا الفصل التركيب الداخلي لنظام قاعدة البيانات أوراكل وفي نهاية هذا الفصل 
ستكون قادرا بمشيئة الله على : 

-١‏ فهم العلاقات بين الجداول 

ر ا ل 

۳- فهم مكونات قاعدة البيانات العلائقية 

-٤‏ فهم العلاقة بين الخادم والمستفبد 

SERVER ell م‎ -° 

٣ام فهم المستفيد‎ ٦ 
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مقدمة في قواعد البيانات العلائقية‎ 


يقدم هذا الفصل التركيب والبناء الداخلي لنظام إدارة قواعد البيانات أوراكل » فيحتوي علې 
وصف سريع لمكونات أوراكل وتعتمد غالبية تطبيقات نظم قواعد البيانات في بنائها على أحد 
نماذج قاعد البيانات التالية: 


Hierarchical Model ( نموذج هيكلي (هرمي‎ -١ 
Network Mode] نموذج شبکكي‎ ٣ 

Relational Model يaأڻلع نموذج‎ -۳ 

0bj‌ec† M0إء1 نموذج شيئي‎ -٤ 


في الماضي کان النموذج الأول ) الهرمي ( الأكثر انتشارا مع أجهزة الكمبيوتر الكبيرة Main‏ 
Frame‏ تم بدا النظام الثاني ( الشبكي ) في الانتشار BE‏ التوسع في بناء وترکیب 
شبكات الحاسب وكانت هناك صعوبات في استخدام النظامين الاول والتاني ( الهرمي والشبكي ) 
نتيجة لاستخدام مؤشرات البرمجة ( sإمtرآه۲‏ ) لربط سجلات البيانات بعضها مع بعض > لذا 
نجد أن إضافة أو تعديل أو حذف السجلات يحتاج إلى المزيد من قهم طبيعة وعمل المؤشرات 
وفي هذه الفترة الماضية طرق برمجة المؤشرات تكتب بلغة الكوبول ([ا080.)). 

أما النموذج العلائقي ١21(‏ ٠1هام‏ ۸) فهو الأكثر سهولة في الاستخدام وفي برمجة تطبيقات نظم 
قواعد البيانات ومن الناحية النظرية الأكاديمية فيلزمك دراسة المفاهيم الأساسية والضروربة لهذا 
النموذج العلائقي لهذا سنركز هنا على 


Relational Data Structure يكل البيانات عة‎ ١ 

Constraint that govern organization of الضوابط الحاكمة للبيانات العلائقية‎ 
data structure 

Operations that are performance data ٽlنlيبll العمليات التي تجرى على هذه‎ -۳ 
structure 


ويعتمد نظام هياكل البيانات العلائقبة (مووطاهاة a1ده0ااه[مR)‏ على هيكل منطقي 
ويطلق عليه علاقة (21 e110‏ R(و‏ على شكل ثنائي الأبعاد (Tow dimensional‏ 
ta struct (‏ يتكون من صفوف وأعمدة ويسمى جدول (ع1ط2٠)‏ هذا بالإضافة 
إلى عناصر البيانات (وأرعصع]1ء هه 5) تسمى في هذه الحالة وعاuطاع))ج‏ علارة 
على هذا يتم تنظيم هذه البيانات الفعلية في وحدة أو وحدات تسمى وم1مں ٣‏ تقسم إلى 
صفوف R0 ws‏ أو )سجlاںÈاٽ Fields Jgaح) Columns öدمnعÎg ( Records‏ ( 
والشكل التالي يبين العناصر الأساسية لجدول الموظقين sعمرهام‏ ص٤‏ 
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fesse Relation (table) ا‎ . 


Attributes (columns) define the field values 
that the relation will store. 


Tuples (rows) contain actual data values. 


The intersection of a column and a row is a 
field that contains a value. 


العلاقة بين الجداول 


لربط علاقة بأخرى تتحتاج إلى طريقة للارتباط . وهذه الطريقة تستخدم حقلا ۴1٥1۵‏ يكون 
موجودا في الجدولين وحقل الارتباط يسمى في الجدول الأول بالمفتاح الرئيسي راج .:إ۲) 
(رعءK‏ للجدول الأول ويسمى يالمفتاح ال (رمK‏ «عءإه۴) في الجدول الثاني 


DEPT Relation 


( Each value for DEPTNO in 
1 DEPTNO DNAME LOC the EMP relation must exist 


as a Primary Key in the 
RESEARCH DALLAS DEPT relation. 


„| SALES CHICAGO 


U... | DEPTNO 


SMITH “71384 | 9,000.0 
ALLEN ° 7415 | 7,500.0 


JONES 5,000.00 


The MGR attribute is a self-referencing Foreign Key. 


نمiجة‏ عاف Relational Model Algebra‏ 
تعرف بانها العمليات التي يتم اجراؤها على جدول أو مجموعة من الجداول تبعا لعلاقة محددة 
ويوجد معاملان ءإهاهإعم0 هما رهم ل والثاني رهم81 والجدول التالي يعدد سبعة انواع 


لهذه 1 لعمليات 


TET 

تجميع الصفوف السجلات من جدولين مع عدم 
النفاح بكر ار سخلات 

تحديد السجلات (الصفوف) المشتركة بين 
جدولین 

ایر اعات ال ی هف ال 
ولا توجد في الجدول الثاني 

إظهار السجلات مع بعض الأعمدة (مصدر 
البيانات) 

إظهار السجلات من جدول مصدر البيانات تبعا 
لمعيار البحث Crit‏ 

وصل كل سجل من جدول البيانات الاول مع 
كل سجل في الجدول الثاني 

وصل وتمديد السجلات من الجدول الأول مع 
مايقابله من سجلات في الجدول الثاني 


نوع العملية مم رآ 
Binary‏ 


Binary 
Binary 
Unary 
Unary 
Unary 


Unary 
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Operationيlnall‎ 
Union 


Intersection 
Difference 
Projection 

Selection 
Product 


Join 
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مكونات قاعدة البيانات العلائقية RDBMS Components‏ 
تتكون قاعدة البيانات العلائقية من : 


)eإ٣مع[ نظام تشغيل ثاعدة البيانات ويطلق عليه‎ ١ 
Data Dictionary ٽlنlyبll تمو‎ -۲ 


ويتكون نظام تشغيل وتنظيم قاعدة البيانات (1ع”إ6) من مجموعة من الوحدات البرمجية 
oftware‏ والذي صمم ليحكم وينظم وينعامل مع البيانات مابين حفظ واسترجاع وطباعة 
وكذلك تحديد المسؤليات وعمل نظم الأمان وحماية البيانات 

وعادة يحتفظ نظام قاعدة البيانات بقائمة من المستخدمين الذين لهم صلاحية للتعامل مع تطبيق 
قاعدة البيانات والشكل التالي يوضح بعضا من مكونات ال 1عمإ في نظام أوراكل 


RDBMS 


مكونات |آ Kere]‏ في نظم قاعدة البيانات 


ويحوي قاموس البيانات رإه ”ها1 و5 وصفا لشكل البيانات ويطلق على هذا الوصف 
Meta Description‏ أو Meta Data‏ وهذا الوصف يرتبط بکافة الکائنا ت واءز ا0 ضمن 
قاعدة البيانات 

وقاموس بيانات أوراكل يحتوي على مجموعة جداول تضم البيانات المخزنة عن طريق 
أ Kernel]‏ وأيضا على كائنات الفهارس وع ×ع ل مآکكائنات العرض و wع‏ ]۷ كائنات الاستعلام 
والاستقnار Function JIgدllgy Procedure ء«lرجإلا تliئl SQL and Query‏ ...!lخ‏ 
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الشكل التالي يوضح كيفية قراءة أو تعديل قاعدة بيانات باستخدام أوراكل‎ 


يتم التعامل مع جمع البيانات المدارة عن طريق [ع.إء» 
بواسطة 51 فالتطبيقات لا تتصل مباشرة مع قاعدة البيانات 


Actual Data 
SQL Requests Tables 
and Results Indexes 


Latalog, 
Mappinzs, 
SeCUrITY 


Datla Dictionary 


1 کک‎ Dala Reposilory 


Oracle 


Kernel 


RDBMS 


شكل العلاقة بین ×٥ ”٥1‏ و 5Q1‏ و قاموس البیانات 
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Cاiء٤/Sما۷ العلاقة بين الخادم والمستفيد(العميل) م‎ 


يتكون نظام أوراكل من مكونين 
\- llخlëدo Server‏ 
۲ المستفيد (العميل - المزود) ٤عiإاC‏ 


Server oli 
يحوي الخادم قاعدة البيانات المركزية ووظائفها » وكذلك كافة العمليات الخلفية لحفظ هذه القاعدة‎ 


ويحوي ايضا أدوات تشغيل وإيقاف قاعدة البيانات 
والشكل التالي يوضح البناء الداخلي لنظام الخادم 


مدير الخادم 
Server‏ 
Manager‏ 


Server pدlخJl‎ 


نظام الاستيراد 
والتصدير 
EXPS80&‏ 

IMPS8O0 


نظ لقعا 
SQL * PLUS‏ 


المترجمات 
Pre‏ 
compliers‏ 


LOADER 


المستفيد )ى ءi[اC‏ 


أما المستفيد ٤م11‏ فيحتوي على برامج الخدمات والبرامج المساعده والتي بمكننا تشغيلها عن 
بعد باستخدام الشبكة كما يتضمن نظام المستفيد الوسيط الرسومي ععه؟إء).! اهء1طمهإ6 الذي 
يسهل علينا استخدامه وتوجد أداة الاتصال بين الخادم والمستقيد وهي8 ع لتقوم بعمليات الربط 
والاتصال عبر الشبكة 


۱- مدر nllشرgع Enterprise Manager‏ 
ويحوي داخله المكونات التالية 


Enterprise Manager عوgرشnئl متحكم مدير‎ 


Assistants jgڏعlwnll‎ -Y 
SQL*PLUS مںعتwlا نظام‎ ۲ 


Schema Manager ٽlنlيبئlا مدير مخطط قاعدة‎ 
Security Manager Ãيرسلا مدير‎ 
Instance Manager ةعبطئl مدر‎ 
Storage Manager jıjختll مدير‎ 
Data Manager ٽlنlيبll مدير‎ 
Backup and Recovery Manager ٽlنlyبl مدير النسخ الاحتياطي‎ 
SQL Worksheet مںعتwالl‎ Jمع ورقة‎ 
Administrator Toolbar Jgؤٺڊnll شريط أدوات‎ 


والشكل التالي يوضج مكونات حزمة البرامج للمستفيد ما٣‏ 


SQL*PLUS مںعتwllا نظام‎ 
Assistants ùgدعlunll‎ 


Enterprise Manager عgرشمئl مدير‎ 


Worksheet 


مدير الطبعة عcمو†‏ یہ1 
Manager‏ 


شريط أدوات المسؤول 
Administrator‏ 
Toolbar‏ 


ملخص الوحدة 


مدير مخطط قاعدة البيانات 
Schema Manager‏ 
مدير النسخ الاحتياطي للبيانات 


Backup and Recovery 
Manager 


مدير التخزين ععه۲ه)S؟S‏ 
Manager‏ 


Enterprise Manager 
Security ةuرصلا مدير‎ 


Manager 


مدير البيانات وا5 
Manager‏ 
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تناولنا في هذا الفصل تعريف التركيب الداخلي لنظام أوراكل وأهم مكوناته والعلاقة بين الجداول 


جمل .501 البسيطة 


أهداف الفصل 


نتااول عملية استرجاع البيانات في حالات مختلفة مستخدمين في ذلك جملة $٤1 ٤٥1‏ وفي 
نهاية هذا الفصل ستكون إن شاء الله قادر على : 


استرجاع البيانات بواسطة جملة 5٤18٣1‏ البسيطة 

فهم متطلبات وإرشادات كتابة جمل 8Q1‏ 

استخدام العمليات الحسابية وأولويات تنفيذها مع جمل اS@Q؟‏ 
اشتخذام الجمل الإلكاقية على البياتات 

استخدام عبارة 0515911/٣1‏ لمنع تکرار عرض البیانات 
غر کن رات الکرں 
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SELECT أساسيات جم‎ 


جlة SELECT‏ 
تستخدم جملة 8818٧1‏ لاسترجاع البيانات المخزنة في جدول أو عدة جداول حيث أن عملية 
الاسترجاع لا تعدل في هذه البيانات ويمكننا من خلال جملة 9518٧1‏ أن نقوم بالتالي: 


-١‏ اختيار وعرض مجموعة معينة من السجلات المخزنة في الجدول 
فرام نات عن کون انون 
۳- استرجاع بيانات مخزنة في جداول مختلفة 


ملاحظة 
يمكن أن نستخدم كل أو بعض هذه المزايا في جملة استفسار واحدة 


ملاحظة 
أوامر محرر یل ۶* SQL‏ | 
هنالك بعض الاوامر البسيطة التي ستساعدك في كتابة وتحرير وتنفيذ الأوامر على محرر SQ‏ 
ومنها 
-١‏ الامر E51١‏ ویمکن کتابته 81 : يستخدم هذا الأمر لتحریر آخر امر تم كتابته على 
محرر 8Q1‏ وعند تنفيذ هذا الأمر ستفتح لك شاشة المحرر (المفكرة) التي يمكنك 
خلالها اعادة تحرير الأمر وعند الانتهاء من ذلك احفظ الامر ثم اغلق شاشة المفكرة 
ولكن لاحظ لا تكتب الفاصلة المنقوطة (;) بعد نهاية الأمر في هذه الحالة فقط 
-١‏ الأمر ۸ وطريقة كتابته (/) ويستخدم لاعادة تنفيذ اخر امر 8@1محفوظ 


الشكل العام لجمل SELECT‏ 


SELECT { * , COLUMN [alies|], ...} 
FROM table name ; 


حيث أن 

COLUMN‏ اسم الحقل 
name‏ _eاbهt‏ اسم الجدول 
alies‏ تسمية العمود 


يمكن أن نضع الرمز * للدلالة على استرجاع جميع حقول الجدول 

كتابة جمل S@1؟‏ 

نوضح فيما بلي بعض القواعد الإرشادية التي يجب أن توضع بعين الاعتبار عند كتابة جمل 
SQL‏ 


-١‏ يمكن كتابة جمل $01 بالحروف الكبيرة أو الصغيرة 
۲- يمكن كتابة جمل 8Q1‏ في عذة أسطر 


۳ لا يمكن فصل الكلمات المحجوزة عبر السطور مثل ٣۴۸0M‏ 
٤‏ اترك مساقات بين مكونات الجملة لتسهيل عملية القراءة 
-٥‏ في برنامج 9Q1 *۴ 11S‏ تكتب الأوامر مع مؤشر 5Q1‏ ويتم تخزين هذا الامر 


مباشرة في الذاكرة 
مثال 
SELECT * FROM s dept;‏ 
1D NAME REGION ID‏ 
Finance 1‏ 10 
Sales 1‏ 31 
Sales 2‏ 32 
Sales 3‏ 33 
Sales 4‏ 34 
Sales 5‏ 35 
Operations 1‏ 41 
Operations 2‏ 42 
Operations 3‏ 43 
Operations 4‏ 44 
Operations 5‏ 45 
Administration 1‏ 50 
rows selected.‏ 12 
لتنفيذ جمل ا8 


S1 نضع فاصلة منقوطة في نهاية الجملة في مؤشر‎ -١ 

- نضع علامة / في نهاية الجملة في مؤشر 9Q1‏ لاعادة اخر امرموجود في ال(إع8u۴)‏ 
۳- نضع علامة / في نهاية الجملة في الأمر في الذاكرة ۴R(‏ ۴۴لا م) 

)8 u ۴]٥إ(لا لاعادة اخر امرموجود في‎ 5Q1 في مؤشر‎ R۸ او‎ R٧0١ كتابة عبارة‎ -٤ 


العمليات الحسابية 


يمكن أن نستخدم العمليات الحسابية عند عرض البيانات دون أن تؤثر هذه المعالجة على 
البياانات المخزنة في الجدول » ويمكن أن يحتوي التعبير الحسابي على اسم الحقل قيمة ثابتة و 
العملية الحسابية 

العمليات الحسابية 


العمليات التي يمكن أن تستخدم هي: 


EE 
لطر .ت‎ 
القسمة ج‎ ۳ 
* برضلا-٤‎ 


ويمكن استخدام هذه العمليات في جميع أجزاء جملة1 S81٤٣‏ عدا الجزء الخاص ب۸N ۴۸0٥0‏ 


أولويات العمليات 
-١‏ الافواس الداخلية ثم الخارجية 
لرك و الفهة 
۳- الجمع والطرح 
ملاحظة 


العملية الإلحاقية 


يمكن أن نجري عملية إلحاق عدد من الأعمدة للجدول أو مجموعة حرفية نصية إلى حقول 
أخرى عند العرض باستخدام العملية الإلحاقية 


مذال 
SELECT first _name| |last name‏ 
EF'ROM s_emp;‏ 


Employees 
CarmenVelasquez 
LaDorisNgao 
MidoriNagayama 
MarkQuick-To-See 


AudryRopeburn 
MollyUrguhart 


توجد مسافات نکتب 


SELECT first name ||' '|| last name FROM s emp; 


DISTINCT öرابع استخدام‎ 


تستخدم عبارة 51511/٣١1‏ لمنع تكرار ظهور بيانات السجل المسترجع فمثلا إذا أردنا أن 
نعرف على الوائف التي ينتسب إليها الموظفون والمخزنة في جدول الموظفين نجد أن هنالك 
وظائف تتكرر حسب عدد الموظفين الذين ينتمون إليها لمنع تكرار نستخدم عبارة 
DISTINCT‏ 


ويأخذ الأمر 9818٣1‏ الشكل التالي: 
SELECT [DISTINCT] { * , COLUMN [alies], ...}‏ 
FROM table name ;‏ 


حيٿث ان 

COLUMN‏ اسم الحقل 
ame‏ _b1eمtk‏ اسم الجدول 
alies‏ تسمية العمود 
(]S1N€1‏ لمنع التكرار 


ملأخص الفصل 


تناولنا في هذا الفصل كتابة جمل 5Q1‏ البسيطة (جملة )5£1٤٣1‏ التي تستخدم في 
استرجاع البيانات وكذلك بعض القواعد الإرشادية التي يجب اتباعها عند كتابة وتنفيذ جمل 
اللآSQ‏ كما تناولنا استخدام العمليات الحسابية مع جملة 9٤E ٤٣1‏ والعملية الإلحاقية 


وكذلك عبارة 019۲1١61‏ التي تستخدم لمنع تكرار ظهور السجلات 
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استرجاع البيانات بشروط ترتيبها 


اهداف الفصل 

-١‏ المعرفة التامة لأسماء الجداول وأسماء الحقول وخصائصها وانواع البيانات 
۲ التعامل مع جمل (SELECT Statement) ةطيڊبll SQL‏ 

۳- استخدام أوامر محرر اSQ؟‏ 


استخدام جم أرط WHERE CLAUSE‏ 
مقدمة 


لقد قمنا في الوحدة السابقة بالتعرف الى جملة اتام llبڊيط (SELECT Statement)‏ 
التي من خلالها تم استرجاع البيانات من الجداول . وفي هذا الفصل سنتابع الحديث عن هذه 
الجملة يشكل أوسع » حيث سنسترجع البيانات من الجداول بناء على شروط معينة › أو مرتبة 
حيث المعاملات الشرطية وطريقة التعبير عن الشرط والترتيب التصاعدي والترتيب التنازلي 


للبيانات 
الصيغة العامة لجملة الشرط 
SELECT SLELETIL yg SELELIA ees sl‏ 
FROM Tablel‏ 
WHERE Condition;‏ 
حيث أن 


Field1.Field2‏ أسماء الحقول التي سيام استرجاع بياناتها 


Table1‏ أسم الجدول الذي سيتم استرجاع البيانات منه 
Condition‏ جملة شرطية آو آکثر تکون نتیجتھا إما مں۲۲ او عی[ه۴ وتتكون من 


أسماء حقول وتعبيرات ومعاملات 
الشرح 


تستخدم جملة ۴ WHER‏ لحصر البيانات التي سيتم استرجاعها من الجداول وهي تحتوي على 
شرط وتقع مباشرة بعد المقطع ۴۸0۷ و عند تنفيذ الجملة سيتم استرجاعها بيانات الحقول 
المذكورة التي تحقق الشرط المذكور في جملة ۴ HR‏ ويمكن أن تقارن الجملة الشرطية بين 
قيم أو حقول في الجدول أو تعبيرات حسابية أي أن جملة ۴ WHER‏ تحتوي على مايلي: 


ه أسماء الحقول 
ه قيم ثابتة 
ه متغيرات وتغبيرات حسابية 


الأمور التي يجب أخذها بعين الاعتبار 


-١‏ عند استخدام حقول النص وحقول التاريخ في جملة الشرط يجب وضع القيم بين علامتي 
تصن مرن( © | 

- فى حالة الحقول النصية يجب مراعاة حالة الأحرف كبيرة أو صغيرة 

۳- في حالة حقول التاريخ يجب مراعاة صيغة التاريخ )۴0۸M۸1(‏ والصيغة الأسا سية 
للتاريخ هي كما يلي D5 5-M0×-¥¥‏ 
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COMPARISON OPERATORS iراقمll معاملات‎ 


E EET 
يساوي‎ = 
أكبر من‎ > 
قل من‎ < 
أكبر من أو يساوي‎ >= 
اقل من أو يساوي‎ >= 
لا يساوي‎ <> 
=إ لا يساوي‎ 


تستخدم معاملات المقارنة في جملة الشرط لمقارنة تعبير بآخر في جملة WHER ٤‏ كما في 
الصيغة التالية : 
تııaر WHERE رuıaî OPERATOR‏ 
مثال 
WHERE hiredate=’01-SEP-96’‏ 


WHERE sal>=1500 
WHERE name=’Ahmed’ 


WHERE sal<> other 
معاملات مقارنة أخرى‎ 
المعامل الال ال‎ 
بين قيمتين‎ NOT BETWEEN BETWEEN 
ضمن قائمة من القيم‎ NOT IN IN 
مطابقة نمط النص‎ NOT LIKE LIKE 
هل هي قسمة فارغة‎ IS NOT NULL IS NULL 


BETWEEN jalal -\‏ 
يستخدم هذا المعامل لاسترجاع بيانات الصفوف التي تعتمد على مدى من القيم أي البيانات التي 


مثال 


SELECT * FROM S EMP 
WHERE sal BETWEEN 1500 AND 2500; 
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أي أنه سيتم استرجاع جميع بيانات الموظفين الذين اقع رواتبهم بين ١٠١٠٠و ٠٠٠١‏ 


| ملاحظة 
ستم استرجاع بيانات الموظف الذي يببلغ راتبه تماما ٠٠٠٠١‏ أو ٠٠٠١‏ أي أن جملة 
BETWEEN‏ تتضمن الحد الأعلى والحد الأدنى للقيم التي سيتم استرجاعها 


۲ المعامل ×1 


يستخدم هذا المعامل للبحث عن قيمة داخل قائمة من القيم فتحتوي هذه القائمة قيما ثابتة أو قد 
تكون هذه القائمة عبارة عن جملة استعلام فرعي 


مثال 


SELECT name, sal , deptno FROM S_ EMP 
WHERE detno IN (10,30); 


أي أنه سيتم استرجاع اسم الموظف وراتبه ورقم القسم الذي يعمل به للموظفين الذين يعملون في 


قسم رقم ٠١‏ أو قسم رقم ٠١‏ 


. 1)۴٤ المعامل‎ ۳ 


المذكورة في جملة الشرط 


مثال 
SELECT * FROM S_ EMP‏ 
WHERE name LIKE ‘S%’;‏ 


أي أنه سيتم استرجاع جميع بيانات الموظفين الذين تبدأً أسماؤهم بحرف ؟$ 


ملاحظة 

تستخدم الاشارة % عوضا عن أي قيمة نصية » قد تكون لا شيء أو أي عدد من الحروف للبحث 
مثلا عن اسم معين ينتهي بحرف ۸ نکتب %۸“ وللبحٿث عن نص يحتوي حرف ۸ نکتب 
۸% وهكذا بإمكاننا أن نبحث عن أي مقطع داخل حقل نصي معين 


مثال 


SELECT * FROM S_ EMP 
WHERE name LIKE ° A%’; 
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أي أنه سيتم استرجاع جمبع بيانات الموظفين الذين يكون الحرف الثاني في أسمائهم هو ۸ 
ملاحظة 
تستخدم الإشارة_عوضا عن حرف واحد فقط 
ئ‘ IS NULL Jalal‏ 
يستخدم هذا المعامل لفحص القيمة (لا شيء) أي قيم القول التي لا تحتوي على بيانات 
مثال 


SELECT name, sal FROM S_ EMP 
WHERE comm. IS NULL; 


اا او ا د ا 
عمو لت 


LOGICAL OPERATORS المعاملات المنطقية‎ 


المعال ERT‏ 
AND‏ یرجع ۲80٤‏ اذا کانت کلتا القیمتین ٤ل 1R‏ 
OR‏ یرجع ۲۸0۴٤‏ اذا کانت احدی القیمتین 1R U٤‏ 
NOT‏ يرجع [RUE‏ إذا كانت lقيaة FALSE‏ 


تستخدم المعاملات المنطقية لترجع قيمة واحدة 1۸0۴ أو ۴۸18۴ كنتيجة بين قيمتين 
منطقيتين او لعكس قيمة منطقية من 1۸0۴ الى ۴۸18۴ والعکس 

من خلال المعاملات المنطقية یمکننا تکوین أکثر من شرط داخل جملة 1٤8٤‏ باستخدام 
المعامل ۸ او المعامل OR‏ 


AND jqماعملا‎ ١ 
۲۸ا٤ يتطلب هذا المعامل أن تکون کلا القیمتین‎ 
مثال‎ 
SELECT name, sal FROM S EMP 


WHERE sal>=2600 AND comm<200; 


أي أنه سيتم استرجاع اسم الموظف وراتبه للموظفين الذين يزيد راتبهم عن ۲٠٠١‏ وتقل 
عمولتهم في نفس الوقت عن ۲٠١‏ أي انه يجب يتحقق الشرطين لاسترجاع البيانات 
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۲ المعامل 0 
يتطلب هذا المعامل أن تكون أي من القیمتین ٤ل‏ 1۸ 
مثال 


SELECT name, sal FROM S EMP 
WHERE sal <200۰ OR deptno=30; 


أي أنه سيتم استرجاع اسم الموظف وراتبه للموفين الذين يزيد راتبهم عن ٠٠٠٠‏ أو يعملون في 


قسم رقم ١‏ آي أنه يجب يتحقق أي من الشرطين لاسترجاع البيانات 
۳ المعامل NOT‏ 
يقوم هذا المعامل بعكس قيمة منطقية من 0۴٤‏ 1۸ إلى ۴۸18۴ والعکس 
مثال 


SELECT name, sal FROM S$ _ EMP 
WHERE deptno NOT IN (20,40); 


أي أنه سيتم استرجاع اسم الموظف وراتبه للموظفين الذين لا يعملون في القسمين رقم ٠١‏ و رقم 


أولويات المعاملات المنطقية ومعاملات المقارنة 


إذا ورد أكثر من معامل منطقي في نفس جملة الشرط فإن أولوية تنفيذ هذه المعاملات من الأعلى 


لی الادئی فی کائالی : 


الأقواس 


معاملات المقارنة (< »> ٠=»‏ <ج) 


NOT 
AND 
OR 


ORD_R BY بيترتll استخدام جملة‎ 


الا ا 


حيث أن 
Table1‏ 
Field1, Field2‏ 
Condition‏ 


Field3 


ASC 
DESC 


ا 


SELECT {ELELAL, ELSLOA Gege} 
FROM Tablel 

WHERE Condition 

ORDER BY Field3 [ASCI|IDESC]; 


اة الحفرل الى س امتر جاع انات هه 

اسماء الحقول التي سبتم اأسترجاع بياناتها 

جملة شرطية أو اکثر تکون نتیجتھا إما eںإ‏ أو می[ه۴ وتتكون من 
اسماء حقول وتعبيرات ومعاملات منطقية 

اسم الحقل الذي سيتم الترتيب بناء عليه 

استرجاع البيانات مرتبة تصاعديا ويجوز عدم ذكرها 

استرجاع البيانات مرتبة تنازليا 


عند استرجاع البيانات تستخدم جملة 8۷ 0۸58۸ لترتيب البيانات حسب حقل معين أو 
عدة حقول وتأتي هذه الجملة في نهاية جملة الاسترجاع $£E1٤٨1‏ وقد يكون هذا الترتيب 
تصاعديا (من القيمة الصغيرة إلى القيمة الكبيرة ) عند استخدام المقطع ۸5٣‏ وقد يكون تنازليا 
(من الفيمة الكبيرة إلى القيمة الصغيرة) عند استخدتم المقطع 5٤8٣‏ 


مثال 


SELECT * FROM S EMP 
WHERE deptno NOT IN (20,40) 
ORDER BY cempno ASC; 


أي أنه سيتم استرجاع جميع بيانات الموظفين الذين لا يعملون في القسمين رقم ٠١‏ ورقم 
٠‏ “وستكون البيانات مرتبة تصاعديا حسب رقم الموظف 


ويجوز كتابة الجملة السابقة دون المقطع ۸6٣‏ كمايلي: 


SELECT * FROM S EMP 
WHERE deptno NOT IN (20,40) 
ORDER BY cempno; 


مثال 
SELECT * FROM S EMP‏ 
WHERE deptno NOT IN (20,40)‏ 
ORDER BY cempno DESC;‏ 


أي أنه سيتم استرجاع جميع بيانات الموظفين الذين لا يعملون في القسمين رقم ٠١‏ ورقم 
٤٠‏ وستكون البيانات مرتبة تنازليا حسب رقم الموظف 


ملخص الفصل 


تناولنا من خلال هذا الفصل موضوع استرجاع البيانات بشروط من الجداول وموضوع ترتيب 
البيانات تصاعديا وتنازليا كما وتطرقنا من خلال دراسة جملة الشرط إلى معاملات المقارنة 
والمعاملات المنطقية ومعاملات أخرى مثل NULL رآN BETWEEN‏ 18 ومایتعلق بھا 
من حيث طريقة الاستخدام وتركيب جملة الشرط وأولويات معاملات المقارنة والمعاملات 
المنطقية 
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الدوال الحرفية 
اهداف الفصل 


في نهاية هذا الفصل إن شاء الله ستكون قادر على : 
-١‏ تحويل الحروف من صغيرة إلى كبيرة وبالعكس من خلال اSQ؟‏ 
آ- ٠‏ اضبط ومحاذاة الخروف داخل النص الموجوذ في $01 
۳ القيام بحذف البيانات من الجداول 
االتعامل مغ اللفظ الصوتي للباتات 
د افا كن تات الحرن 


mean 
الدال الحرفية والضبط والمحاذاة‎ 


دالة تحويل البيانات إلى حروف صخiيرة LOWER Function‏ 


تسنخدم هذه الدالة لتحويل البيانات من حروف كبيرة إلى حروف صغيرة ويتم استخدام هذه الدالة 
غاليا مع جمل أخرى 


الشكل العام انظر المثال التالي 
مثال . 


SELECT LOWER (name), LOWER (job) 
FROM S_EMP; 


سيتم عرض اسم الموظف ووظبقته ولكن بحروف صغيرة 


LOWER name LOWER job 
ali salesman 
ahmed analyst 
sami manager 
khaled manager 


دالة تحويل البیانات إلى حروف کبıرة UPPER Function‏ 


تسنخدم هذه الدالة لتحويل البيانات من حروف صغيرة إلى حروف كبيرة ويتم استخدام هذه الدالة 
غاليا مع جمل أخرى 


مثال 
SELECT UPPER (name), UPPER (job)‏ 
FROM S_EMP;‏ 


دالة تحويل الحرف الأول من البيانات إلى حرف كبير 1N1۲٣۳۸۶‏ 


تستخدم هذه الدالة لتحويل أول حرف من بيانات الحقل المحدد إلى حرف کبير ويتم استخدام هذه 
الدالة غالبا مع الجمل أخرى 


مثال 
SELECT INITCAP (name), INITCAP (job)‏ 
FROM S_EMP;‏ 
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سیتم عرض اسم الموظف ووظبقته ولکن اول حرف في کلاهما سیکون کبیر 


INITCAP name INITCAP job 
Ali Salesman 
Ahmed Analyst 
Sami Manager 
Khaled Manager 


دالة اقتطاع (قص) جزء من بيانات الحقّل 18 8S‏ 1اS؟‏ 


تستخدم لعرض أو قص جزء معين من بيانات العمود او الحقل 


الصيغة العامة 
SUBSTR(Field1,N,M)‏ 
حيٿث ان 
String‏ الحقل المراد الاقتطاع منه 
N‏ اول حرف یبدا عنده الاقتطاع 
M‏ عدد الحروف المراد اقتطاعها 
مثال 


SUBSTR(Ahmed',1,3) 
قيكون الناتج‎ 
Ahm 


مذال 
SELECT SUBSTR (name, 1,2)‏ 
FROM S_EMP:;‏ 


سيتم اقتطاع الحرف الأول والثاني من اسم الموظف وعرضها 
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دالة تحديد موقع حرف في بيانات حقJ INSTR Function‏ 


تستخدم هذه الدالة لتحديد مكان أو موقع حرف في بيانات العمود أو الحقل 


الصيغة العامة 
INSTR (Field, ‘C?)‏ 
حيث أن 
Field‏ الحقل الذي سيتم التحديد منه 
C‏ إلخر ت المر اه امراج :م 
مثال 
SELECT INSTR (name, ‘1)‏ 
FROM S_EMP;‏ 
سيتم استخراج موقع الحرف 1 من حقل اسم الموظف 
INSTR name‏ 
2 
0 
0 
4 


دالة ضبط ومحاذاة ناحية الیمین dأبيlنlٽت RPAD Function‏ 


تستخدم هذه الدالة لمحاذاة البيانات ناحية اليمين حيث يتم ملء حرف معين (أو حروف ) يمين 


البيانات 
الشكل العام 
RPAD (COL | VALUE, N, °` String’)‏ 
حيٿ أن 
COL‏ اسم الحقل المطلوب محاذاة بياناته » ووضع حرف (حروف) يمينه 


( ( یمکن وضع قيمة أو متغير حرفي بین علامتي تنصب‎ VALUE 
عدد مرات ظهور الحرف الجديد‎ N 


moon 


String‏ الحرف أو المتغير الذي سيتم ملء الفراغات به 


مذال 
SELECT name, RPAD (sal, 7,'$7')‏ 
FROM S_EMP;‏ 


NAME RPAD SAL 

Ali 9685$$5% 
Ahmed 1936$$$% 
SAMI 1512:55 
KHALED 3599.75 


دالة ضبط ومحاذاة ناحية الیسار dأبيlنlٽ LPAD Function‏ 


تستخدم هذه الدالة لمحاذاة البيانات ناحية اليمين حيث يتم ملء حرف معين (أو حروف ) يسار 


البيانات 
الشكل العام 
LPAD (COL | VALUE, N, °` String’)‏ 
حيث أن 
COL‏ اسم الحقل المطلوب محاذاة بياناته » ووضع حرف (حروف) يمينه 
A1۳٤‏ يمكن وضع قيمة أو متغير حرفي بين علامتي تنصيص (" ") 
String‏ الحرف أو المتغير الذي سيتم ملء الفراغات به 
مثال 


SELECT name, LPAD (sal, 7,’ #') 
FROM S_EMP; 


NAME LPAD SAL 
Ali ####968 
Ahmed ###1936 
SAMI #1512.5 


KHALED 3599.5 
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دالة حذف بيانات ناحية يمين lائحJa RTRIM Function‏ 
تستنخدم هذه الدالة لحذف بيانات من ناية يمين العمود او الحقل المحدد 


اة اة 
RTRIM (COL | VALUE, ` String’ )‏ 


A1٤‏ القيمة البديلة للعمود 
String‏ قيمة الحرف أو المتغير الذي سيتم البحث عنه 


SELECT name, RTRIM (job.'man'’ ) 
FROM S_EMP; 


سیتم حذف جص من يمين العمود 0ز 


name RTRIM job 
ALI Sales 
AHMED Analyst 
SAMI Manager 
Khaled Manager 


دالة حذف بیانات يسار ائحJa LTRIM Function‏ 
تستخدم هذه الدالة لحذف بيانات من ناحية يسار العمود أو الحقل المحدد 


الشكل العام 
LTRIM (COL | VALUE, ` String’)‏ 
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۷A٤‏ للقيمة البديلة للعمود 
String‏ قيمة الحرف أو المتغير الذي سيتم البحث عنه 


SELECT name, LTRIM (job.'man'’ ) 
FROM S_EMP; 


سیتم حذف ۸ص من يسار العمود اهز 


name LTRIM job 
ALI Salesman 
AHMED Analyst 
SAMI ager 
Khaled ager 


دالة قياس طول بيانات ائحaقJ LENGTH Function‏ 
تستخدم هذه الدالة لإيجاد طول بيانات متغير أو الحقل المحدد 


الشكل العام 
LENGTH (COL | VALUE)‏ 


مٿال 
SELECT LENGTH (name), LENGTH (‘WELCOME )‏ 
FROM S_EMP;‏ 

سيتم حساب طول اسم الموظف وطJ‏ nlة WELCOME‏ . 


LENGTH name LENGTH ‘WELCOME? 
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دالة تعديل بيانات في جدJa TRANSLATE Function‏ 
تس تستخدم هذه الدالة أنعديل أو أتبديل بيانات موجودة في جدول معیين 


الشكل العام: 
TRANSLATE (COL| VALUE, FROM, TO)‏ 


VALUE‏ القيمة البديلة للعمود (البيانات) 
FROM‏ الحرف (الحروف) المطلوب تغييره 
TO‏ الحرف (الحروف) المطلوب احلاله 


SELECT name, TRANSLATE (name,'MI’,'WY7’) 
FROM S5 EMP WHERE Sal=1512.5; 


سيتم استبدال الحرفين M1‏ بالحرفين #۷ 


name TRANSLATE (name) 


دالة عرض اللفظ الصوتي SOUNDEX Function‏ 


تستخدم هذه الدالة لإيجاد اللفظ الصوتي للبيانات (المتغيرات) الموجودة في جدول معين حتى ولو 
كان هناك اختلاف في بعض الأحرف الهجائية 


SOUNDEX (COL| VALUE) 


COL‏ اسم القل أو العمود 


A1٤‏ للقيمة البديلة للعمود (البيانات) 
مثال 


SELECT name, SOUNDEX (name) 
F'ROM S_EMP WHERE sal=1512.5; 


ملخص الفصل 
تناولنا الدوال الحرفية الخاصة بتحويل حالة الحروف من حروف كبيرة إلى حروف صغيرة 


Moon 
دوال التاريخ والتحويل‎ 


أهداف الفصل 

في نهاية هذا الفصل إن شاء الله تكون قادر على : 
١‏ التعامل مع دوال التاريخ في 8Q1‏ 
التعامل مع أدوات التحويل في $1 


دوال التاريخ 
الوفت هو الحياة والتاريخ هو أصل الامم لذا لتا لنتعمق في كيفية استخدام دوال التاريخ 
الدالة Sysdate‏ 


هذه الدالة تقوم بإعطاء تاريخ اليوم الحالي أي التاريخ المخزن في جهاز الكمبيوتر الذي ينفذ عليه 
يجب أن تتم عملية استدعاء التاريخ من هذا الجدول 

مثال 

لاستدعاء تاريخ اليوم الحالي نقوم بالآتي : 


SELECT SYSDATE FROM DUAL; 


NEXT_DAY lll 


تستخدم هذه الدالة لعرض التاريخ الذي يوافق التاريخ التالي للتاريخ المعطى 
فعلى سبيل المثال إذا كان التاريخ الموجود هو ۲٠٠۳/۷/۷‏ وطلب من الجهاز تحديد اليوم الذي 
يصادف يوم الجمعة من نفس الشهر فإنه يعطي 7/۷/11 


الشكل العام 
NEXT DAY (DATE, CHAR)‏ 


حيث إن ۸1۴( هو التاريخ المعطى والمراد إيجاد التاريخ لليوم الذي يليه من خلال وضع اسم 
اليوم داخل المتغير AR‏ ]€8 


مثال 
SELECT NEXT DAY ('7/7/2003' ,' MONDAY’ ) FROM DUAL;‏ 


نتيجة التنفيدذ 


o 


NEXT DAY 


11/7/203 
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دالة تحدید الیوم الأخیر من کل شهر 5۸۷ ۲؟۸_ 
تقوم هذه الدالة بتحدید آخر یم من كل شهر معطى 


الشكل العام 
LAST DAY (DATE)‏ 


حيث أن 0۸1۴ هو تاريخ الجهاز أو تاريخ تقوم بإدخاله 
مال 
SELECT LAST DAY (SYSDATE) FROM DUAL;‏ 
بفرض أن تاريخ الهاز 1۴ $۲95۸ هو ۲٠٠٠/۲/۲‏ فإن نتيجة للجملة السابقة هي كما يلي : 
LAST_DAY(SYSDATE)‏ 


28/2/2033 


ملاحظة 
يمكنك أن تقوم بطرح تاريخ من تاريخ آخر كالمثال التالي 


SELECT SYSDATE - HIRDATE FROM S_ EMP 


حیث H]]R D۸1۴‏ حقل تاریخ . 


الدالة MONTHES_ BETWEEN‏ 
تستخدم هذه الدالة لعرض مدة الفرق بين شهرين 


الشكل العام 
MONTHES_ BETWEEN (DATE1,DATE2)‏ 


مثال 
MONTHES_BETWEEN (’ 01-SEP-95’ ,'11-JAN-94° )‏ 


سيكون الناتج 
1.9774194 
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ADD_ MONTHES Jll 
تستخدم هذه الدالة لإضافة عدد من الأشهر إلى التاريخ معطى‎ 
ADD_MONTHES (DATE, M) 


أن 


3 


DATE‏ التار يخ المعطى 
M‏ عدد الاشهر 


ADD _MONTHES ('7-JAN-99’ ,6)‏ 
عند التنفيذ سيكون الناتج 


7-JUL-99 


ROUND ill 

تستخدم هذه الدالة لعرض اقرب بداية شهر أو سنه لتاريخ معين تحدده 

ملاحظة :تستخدم هذه الدالة أيضا للبيانات الرقمية للتقريب وسيتم شرحها في باب الدوال الرقمية 
الصيغة العامة 


ROUND (DATE, M|Y) 


DATE‏ التاريخ المعطى 
M‏ نکتب 18 ٥×N‏ ×" اذا اردنا ان یعود باقرب شھر 
Y‏ نکتب E۸۸‏ ۲ اذا اردنا ان یعود باقرب سنة 


ROUND (’ 07-MAY-96’ , ‘MONTH’ ) 


moon 
عند التنفيذ سيكون الناتج‎ 
01-JUN-96 


مثال 
ROUND (’ 07-MAY-96’ , ‘YEAR’ )‏ 


عند التنفيذ سيكون الناتج 
01-JAN-96‏ 


llدllة TRANCATE Function‏ 
تستخدم هذه الدالة لعرض تاريخ اول يوم في شهر أو سنه لتاريخ معين تحدده 
ملاحظة :تستخدم هذه الدالة أيضا للبيانات الرقمية للتقريب وسيتم شرحها في باب الدوال الرقمية 


الصيغة العامة 


TRUNC (DATE, M|IY) 


DATE‏ التاريخ المعطى 

M‏ نکتب ۱×٥۵×N1۳8‏ اذا اردنا ان یعرض تاریخ اول یوم في شھر 
التاريخ المحدد 

Y‏ نکتب ۲8۸ اذا اردنا ان یعود لأول يوم لنفس سنة التاریخ 


TRUNC (’ 07-MAY-96’ , ‘MONTH’ ) 


عند التنفيذ سيكون الناتج 
01-MAY-96‏ 


مثال 
TRUNC (’ 07-MAY-96' , ‘YEAR’ )‏ 


عند التنفيذ سيكون الناتج 
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01-JAN-96 
دوال التحويل‎ 
يتم تحويل البيانات من شكل إلى اخر وتوجد دوال خاصة بالتحويل ومنها‎ 
۲0_٤1۸ التحویل الى حروف‎ 
TO_NUMBFR التحويل إJٴ رق‎ 
10_5۸ 1۴ التحویل إلى تاریخ‎ 
TO_CHAR lll 


تستخدم هذه الدالة لتحويل التاريخ او الأرقام الى جملة حرفية حيث يتم تغيير شكل التاريخ او 
الارقام من صورة إلى اخرى 


اولا من تاريخ الى جملة حرفية 


الشكل العام 
TO_CHAR (DATE,’ FMT’)‏ 

حيث أن 

DATE‏ قيمة التاريخ 

FMT‏ الصورة الجديدة 

مذال 


SELECT TO_CHAR (SYSDATE,’' DAY, DD MON YY”) 
FROM DUAL; 


لنفرض أن تاريخ الجهاز (S50۸18؟8S۷)‏ هو ۲٠٠۳/۷/۷‏ فإن نتيجة التنفيذ للجملة السايقة هي 
TO CHAR (SYSDATE,' DAY, DD MON YY7’)‏ 


MONDAY 7 JUL 03 


ملاحظة 
ا کک شرت کے ر کن اا گام مع د۲۰ 
اذا كتبنا ۷" فإنه سوف يتم عرض رقم الشهر متلا 06 
اذا کتبنا 18 ×٥ ×N‏ فانھ سوف یتم عرض اسم الشھر کاملا متل راں[ 
اذا كتبنا ۷سيتم عرض أول تلاثة حروف من اليوم 
اذا کتبنا 5۸۷ سیتم عرض اسم الیوم کاملا 
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15:45:32 PM Jûم‎ HH24:M1:8$S AM اذا اردنا عرض الساعة نكتب‎ ١ 


ثانيا التحويل من أرقام الى جملة حرفية 
الشكل العام 

TO_CHAR (NUMBER, ’ FMT’ ) 
حيث أن‎ 


مقرللl‎ NUMBER 
الصورة الجديدة‎ FMT 


مثال 


SELECT TO_CHAR (6500500, $9,999,999) 
FROM S_EMP; 


عند التنفيذ سيكون الناتج 


TO CHAR (6500500, $9,999,999) 


6,500,500 


ملاحظة 

عندما نكتب 9 فإننا نعني يها خاتة رقم 
عندما نكتب ( , ) يتم طباعة الفاصلة 
عندما نكتب( . ) يتم طباعة الفاصلة العشرية 


TO_NUMBER ÃذIنl‎ 


تقوم هذه الدالة بتحويل القيمة الرقمية المخزنة عى شكل حرف C14۸‏ إلى قيمة رقمية فعليه 
NUMBER‏ 


الشكل العام 
TO_NUMBER (VALUE)‏ 


* 


2 


A1٤‏ قيمة مخزنة على شكل أرقام حرفية سيتم عرضها على شكل قيم رقمية 


moon 


ل 
لنفرض أن لدینا حقل اسمه N0۷‏ في جدول 5۸۲۸ به ارقام ولکنها ارقام حرفیه أي انها 
تعامل معاملة الحروف فلا تدخل في العمليات الحسابية فعند تنفيذ هذه الدالة ستم تحويل القيم إلى 
فيم رقمية يمكن ان تدخل في العمليات الحسابية 


SELECT NUM, TO_ NUMBER (NUM) 
FROM DATA; 


عند التنفيذ سيكون الناتج 


NUM TO NUMBER(NUM) 
9236 9236 
7526 7526 
ملاحظة‎ 


العمودان بهما نفس القيم ولكن يوجد اختلاف في النوع 


TO_DATE alll 


تقوم دة الذالة تتكوؤيل المتغير الحر في دأخل فار النض الى متعين بشكل قار يخ الال التالى 
يوضح ذلك : 
SELECT TO_DATE (JULY 7,2003’, MONTH DD, YY”)‏ 
FROM DUAL;‏ 


عند التنفيذ سيكون الناتج 


TO DATE (JULY 7,2003’, MONTH DD, YY?) 


07-JUL-03 


ملخص الفصل 
تناولنا في هذا الفصل دوال التاريخ الخاصة بالتعامل مع كامل الصيغ للتاريخ والوقت 
واستعراضها بعدة أشكالها ثم تطرقنا دوال التحويل التي تعمل تحويل حالات الكتابة من نص إلى 


ت 


moon 
الدوال الرقمية‎ 
أهداف الفصل‎ 


فى نهاية هذا الفصل ان شاء الله ستكن قادر على 

- التعامل مع دالة القيمة المطلقة 
إيجاد الجذر التربيعى للأعداد 
التعامل مع الدالة الأسية للأعداد 
تقريب الأعداد العشرية من خلال اSQ؟‏ 
تقريب الأعداد من خلال حذف المنزلة العشرية 
إيجاد باقى القسمة للأعداد 
ايجاد اشارة الأعداد السالبة 


ABS Function ةقذlطآملا دالة القيمة‎ 


الدوال المطلقة والأسية والأسية والجذر التربيعي 


moon 


تستخدم هذه الدالة لإيجاد القيمة المطلقة لرقم معين وغالبا يتم استخدان هذه الدالة مع جمل أخرى 


الشكل العام 


حيث آن 


COL 
VALUE 


مثال 


name, job,hiredate-sysdate FROM S EMP; 


اسم الحقل أو العمود 


القيمة البديلة للعمود (البيانات) 


عند التنفيذ سيتم طباعة: 


hierdate-sysdate 
-6906. 32 
-6841. 2 
-4592. 2 
62 


Salesman 


Analyst 
Manager 
Manager 


ABS (COL|VALUE) 


SBEBCGE 


AHMED 
SAMI 
Khaled 


نلاحظ أن قيم العمود مهلءرء-مهل۲ء1ط قيم سالبة ولكي نجعلها دائما موجبة نأخذ القيمة 
الط ل ان وک 


FROM S_EMP; 


عند التنفيذ سيتم طباعة: 
hierdate-sysdate‏ 


6906.3252 
6841.3252 
4592.32 
6555.32 


name, job, ABS (hiredate-sysdate) 


Salesman 
Analyst 
Manager 
Manager 


SELECT 


SAMI 
Khaled 
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POWER Function اأص‎ ةlIدl‎ -1 


تستخدم هذه الدالة لإيجاد قيمة رقم مرفوع لأس 


الشكل العام 
POWER (COL| VALUE ,P)‏ 
حيث أن 
COL‏ اسم الحقل أو العمود 
A1٤‏ القيمة البديلة للعمود (البيانات) 
P‏ قيمة الأس 
مثال 


SELECT DIGIT, POWER (DIGITLl, 2) FROM DIGIT; 


عند التنفيذ سيتم طباعة: 


DIGIT1 POWER (DIGIT1, 2) 
20 400 

25 625 

25.5 650.25 

30.5 930.5 


۳- دالة الجذر التربيعي SQRT Function‏ 
تنس تستخدم هذه الدالة لإياد الجذر التربيعي لرقم معين 
الشكل العام 


SQRT (COL|VALUE) 


COL‏ انتم اللحفل اى اموه 
A11٤‏ للقيمة البديلة للعمود (البيانات) 
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مثال 
SELECT name,sal, SQRT (sal) FROM S EMP;‏ 


عند التنفيذ سيتم طباعة: 


NAME SAL SQRT (SAL) 
Ali 968 31.113 
Ahmed 1936 44 

SAMI 1512.5 38. 9805 


KHALED 3599.5 59.988 


maon 
دوال التقريب وباقي القسمة والإشارة‎ 


ROUND Function يرضشعlلا دالة التقريب‎ 


تستخدم هذه الدالة لتقريب العدد إلى اقرب رقم عشري أو صحيح 


الشكل العام 
ROUND (COL|VALUE, N)‏ 

حيث أن 

COL‏ اسم الحقل أو العمود 

A1٤‏ قيمة عددية 

N‏ عدد المواقع العشرية 

مثال 


SELECT SQRT (sal), ROUND (SQRT (sal), 2) FROM S_EMP; 


عند التنفيذ سيتم طباعة: 


SQRT (SAL) ROUND (SQRT (sal), 1) 
31.113 S1 

44 44 

38.95 38.98 

59.988 59.99 


دالة التقريب ڊlئھذزف TRANCATE Function‏ 
ا ر ت ر ا 
الشكل العام 


TRUNC (COL|VALUE,N) 


COL‏ اسم الحقل أو العمود 
A11٤‏ قيمة عددية 
N‏ عدد المواقع العشرية 


moan 
مثال‎ 


SELECT DIGIT1, TRUNC (DIGIT1,-1), 
TRUNC (POWER (DIGIT1,2),1) FROM DIGITS; 


عند التنفيذ سيتم طباعة: 


DIGIT1 TRUNC (DIGIT1, -1) TRUNC (POWER 
(DIGIT1, 2), 1) 


20 20 400 
25 20 625 
25.5 20 650.2 
305 30 930.2 


MOD Function مaınقلl دالة باقي‎ 


تستخدم هذه الدالة لإيجاد باقي قسمة عددين 


الصيغة العامة 
MOD (VALUE1, VALUE2)‏ 
حيث أن 
VALUE1I‏ قيمة عدد بة 
VALUEZ2‏ قيمة عددية 
مثال 


SELECT DIGIT1I, MOD (DIGITI, 7) FROM DIGITS 


عند التنفيذ سيتم طباعة: 


DIGIT1 MOD (DIGI1, 7) 
20 6 

25 4 

25.5 4.5 

30.5 2.5 
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SIGN Function ةرlشضإلا‎ ةllد‎ 


تستخدم هذه الدالة لفحص إشارة الرقم فإذا كانت الإشارة موجبة تعود بالقيمة )١(‏ أما اذا كانت 
الإشارة سالبة فتعود بالقيمة )-١(‏ 


الشكل العام انظر المثال التالي : 
مثال 


SELECT DIGIT1I, SIGN (DIGITI) FROM DIGITS 


DIGIT1 MOD (DIGI1, 7) 


ملخص الفصل 


تناولنا في هذا الفصل الدوال الرقمية في لغة الاستعلام والاستفهام في نظام قواعد البيانات 
اوراكل وقد قسمنا هذه الدوال حسب وظائفها فمنها مايتعامل مع سجل أو صف من البيانات 
ومنها مايتعامل مع مجموعة من السجلات 8R ٤٨0R 5S8‏ او الأعمدة (C010 MNS‏ الحقول) 
حيث تطرقنا الى دالة القيمة المطلقة والدالة الاسية والجذر التربيعى وكذلك دوال التقريب ودالة 
باقي القسمة والاشارة 


meen 
استرجاع البيانات‎ 
أهداف اافصل‎ 
ان شاء الله بعد دراسة هذا الفصل ستكون قادر على‎ 


-١‏ استرجاع البيانات من أكثر من جدول 
۲ استرجاع البيانات بأسماء مستعارة 


استرجاع البيانات من أكثر من جدول 


نستطيع استرجاع بيانات من أكثر من جدول اذا كان بينهم علاقة ه1اهآمR‏ حيث كل صف من 


احدهما يرتبط مع صف من الاخر عن طريق حقل مشترك 


SS _USPT abl 


tridrTE jaf nT 


= 


وتوجد عدة أنواع للربط : 
EQUAI JOIN-'1‏ 
الصيغة العامة 
table.column‏ 


= table2.column2; 


تا ر a‏ 


Tela U EE 
A Hgar 
I: Temar 
TE EHTS 
5 Hopebuara 
Û TrTiakimr E 
Y HERZE 
1 
A Ceatalpole 
1 TF 
. Hege? 


HI 


i. ETE 


SELECT table.column, 
FROM tablel, table2 
WHERE tablel.columnl 


حيث نكتب بعد 95£E1٤S1‏ الاعمدة التي نريد ظهورها ولاحظ كذلك أنه من الضروري كتابة 
الاعمدة التي عن طريقها تم الربط(التي يتساوى فيها الحقول في الجدولين) ونكتب بعد كلمة 
WHERE‏ العمودان اللذان تم ربط الجدولين عن طريقهما 


ملاحظة 


نكتب اسم الجدول اولا ثم اسم العمود وبینھما نقطه ہہ ں c٥1‏ .1eطaخ‏ 


مثال 


MEJER Ju 
IH FIETT Jars 
 EANFEES 
RRO FEET 
UOFERERIOTE 
 IREBEAPBIONE 

Sd DB EHET pass 

bS PE EOEIONE 


SELECT S$ EMP.DEPT 1D, S$ EMP.LAST NAME, S_DEPT.NAME 
FROM S5 EMP, S_ DEPT 
WHERE S EMP.DEPT ID = $S DEPT.ID; 


عند التفيذ ينتج 
DEPT ID LAST NAME NAME‏ 
VELASQUEA ADMINISTRATION‏ 50 
NGAO OPERATOPNS‏ 41 
NAGAYAMA SALES‏ 31 
ROPEBURN ADMINISTRATION‏ 50 
URGIHART OPERATOPNS‏ 41 
MENCHU OPERATOPNS‏ 42 
BIRI OPERATOPNS‏ 43 
HAVEL OPERATOPNS‏ 45 


ویمکن اضافة شرط اخر بعد WH] ER٤‏ وذلك باستخدام ۸ND‏ فنکتب 


SELECT S5 EMP.DEPT 1D, S$ EMP.LAST NAME, S_DEPT.NAME 
FROM S5 EMP, S_DEPT 
WHERE S EMP.DEPT ID = S$ DEPT.ID AND S DEPT = 41; 


DEPT ID LAS T NAME NAME 
41 NGAO OPERATOPNS 
41 URGIHART OPERATOPNS 


NON- EQUAI JOIN-Y 
يستخدم هذه النوع عندما لا يوجد اعمدة مشتركة بين الجدولين‎ 


مثال 
SELECT S_EMP.ename, S8 EMP.job, S EMP.sal,‏ 
salgrade.grade‏ 
FROM S EMP, salgrade‏ 
WHERE S EMP.sal BETWEEN salgrade.losal AND‏ 
salgrade.hisal;‏ 


OUTER JOIN-Y 


يستخدم هذا النوع لرؤية السجلات في الجدول الثاني التي لا يقابلها سجلات في الجدول الأول 


الصيغة العامة 
SELECT table.column, table.column‏ 
FROM tablel, table2‏ 
WHERE tablel.column (+) = table2.column;‏ 
ملاحظة 


نسنخدم المعامل (+) في هذا النوع من الربط حيث نكتبه بجوار الاسم الحقل الذي لا يحتوي على 
قيمة 


ا ار اة 
Ig HRA HERAN‏ 
OEE‏ 
KHATER ON SOTNOLEH‏ 

E HANE AHOEL 
EEE NE 
EFREER EOEHEPTEEE 


اذا اردنا الاستعلام عن الجزء الذي لا يتواجد به موظف نكتب 


SELECT s emp.last_ name, s emp.id, , 
S_customer.name 

FROMs emp, s_ customer 

WHERE s_emp.id (FF) = s customer.sales rep id 
ORDER BY s_ emp.id; 


SELF JOIN-‘ 
تستخدم لربط صف من جدول بصف اخر من نفس الجدول‎ 


HAST HAE HAHRGE AO) j 1 


VENBSNNEE 
TD ENEBSINEE 
HEG 
HGEG 
HEG 
ازور‎ 
ودراد‎ 


HEQNEVATE 
HOPEP ET 
UETOTEED 
HEMT 
BIE 
HEEE 
Ag MT 


1 1 
1 4 
1 1 
ر 2 
ر 2 
2 2 
3 8 
8 3 


: مثال‎ 
SELECT worker.last_ name||' works for '|| 
manager.last_ name 
FROMs emp worker, s emp manager 
WHERE worker.manager id = manager.id; 


worker.last_ name||' works for '| | 
manager.last_ name 
Nago works for Velasquez 
Nagayama works for Velasquez 
Ropeburn works for Velasquez 
Urguhart works for Nago 
Biri works for Nago 
Magee works for Nagayama 
Gil jum Nagayama 


meen 
استرجاع البيانات بأسماء مستعارة‎ 


في اخر مثال قمنا باستدعاء الجدول م صه ۽ باسم مستعار )مس ومرة أخرى ياسم 
manager‏ وهذا الاسم يقوم محل اسم الجدول وقد استخدمناه للتسهيل 


SELECT e.ename, e.job, e.sal, s.grade 
FROM S_EMP e, salgrade s 
WHERE e.sal BETWEEN s.losal AND s.hisal; 
مثال‎ 


SELECT e.last_ name, e.id, c.name 
FROMs S5 EMP e, s_ customer cC 

WHERE EIA (FY 2E. Sales. FeD 1d 
ORDER By e.id; 


ا ك افع ج 0ة انخاصة بار جاع بات هن اکر من چول كرض ر 

اقسام الموظفين من جدول الموطفين وتطرقنا كذلك إلى عملية استرجاع البيانات من خلال اسم 
a‏ 
ر 


و 
الدوال الرياضية والإحصائية ودوال المجموعات 

أهداف الفصل 

في نهاية هذا الفصل ان شاء الله ستكون قادر على : 


١‏ الان هة ادرال ار اة وال حصا 


moon 
الدوال الرياضية والإحصائية‎ 


لإخراج قيمة واحدة محدودة ومن هذه الاقترانات مايلي: 


COUNT دعdا دالة‎ ١ 

۲ دالة أكبر قيمة×M۸‏ 

۳ دالة أصغر قيمû MIN‏ 

SUM دالة المجموع‎ -٤ 

۸۷6 دالة المتوسط الحسابي‎ ٥ 

S15055٤۷ دالة الانحراف المعياري‎ ١ 

VARIANCE رlيعall‎ ll -۷ 
COUNT ذدآûdا دالة‎ ١ 


تقوم هذه الدالة بعملية حصر الحقول في عمود معين والتي لا تحمل القيمة 1× 


الشكل العام 
COUNT (DISTINCTIALL | EXP)‏ 
حيث أن 
DISTINCT‏ تستخدم لمنع احتساب الحقول التي تحمل القيمة 01× 
ALL‏ يكون المدى هنا جميع الحقول حتى المكررة 
EXP‏ یمکن استخدام اسم العمود 
مثال 


SELECT COUNT (DISTINCT NAME) FROM S_ EMP; 
S_EMP Jودجلا من‎ N۸ M٤ تقوم الجملة السايقة بتحديد عدد الصفوف للحقل‎ 
مثال‎ 
SELECT COUNT (*) “TOTAL” FROM S EMP; 
M4× دالة أكبر قيمة‎ -١ 
تقوم هذه الدالة بعرض أكبر قيمة موجودة في عمود معين‎ 
الشكل العام‎ 


MAX (DISTINCT| ALL | EXP) 


moon 


SELECT MAX (DISTINCT salary) FROM S_ÃEMP; 


تقوم هذه الجملة بعرض أكبر راتب في جدول الموظفین N۲‏ ٤_S؟‏ 


۳ دالة أکبر قیمة MIN‏ 
تقوم هذه الدالة بعرض أكبر قيمة موجودة في عمود معين 
الشكل العام 
MIN (DISTINCT| ALL | EXP)‏ 


مثال 
SELECT MIN (DISTINCT salary) FROM S_ EMP;‏ 


تقوم هذه الجملة بعرض أصغر راتب في جدول الموظفین N۲‏ ٤غ_S؟‏ 


؛>- دالة المجموع MاS‏ 
تقوم هذه الدالة بعرض مجمو ع القيم الموجودة في حقل او عمود معين 
SUM (DISTINCT| ALL | EXP)‏ 


مثال 
SELECT SUM (salary) FROM S_ EMP;‏ 


تقوم هذه الجملة بعرض مجموع رواتب الموظفين في جدول الموظفین N۶۴٤_S؟‏ 


۸۷6G دالة المتوسط الحسابي‎ ٥ 
تقوم هذه الدالة بعرض المعدل لمجموعة قراءات قد تكون موجودة في جدول معين‎ 
الشكل العام‎ 
AVG (COLUMN) 


0L0 MN‏ هو اسم العمود الموجود في جدول معین 


مثال 


SELECT AVG (SALARY) FROM S EMP; 
تقوم هذه الجملة بحساب المتوسط الحسابي لمرتبات الموظفين‎ 
؟ŠS1055٤۷ دالة الانراف المعياري‎ ٦ 
تقوم هذه الدالة بإيجاد الانحراف المعياري لمجموعة مشاهدات أو قراءات‎ 


الشكل العام 
STDDEV (DISTINCT|ALL)‏ 


مثال 
لإبجاد الانحراف المعياري للأرقام الواردة في حقل الرواتب في جدول الموظفین ۷۴ ٤_$؟‏ 


SELECT STDDEV (SALARY) FROM S EMP; 
VARIANCE رlيعall‎ ll ۷ 
تقوم هذه الدالة بإيجاد المعيار لمجموعة مشاهدات أو قراءات‎ 


منال 
SELECT VARIANCE (SALARY) FROM S_ÃEMP;‏ 


دوال المجموعات 


هي عبارة عن جميع الدوال السابقة او أي دوال اخرى ولكن باستخداماها مع الدالة 
B۴00 BY‏ ممايؤدي إلى تجزئة الجدول الرئيسي إلى مجموعات اصغر منه حسب شرط 
معين 


الشكل العام 
GROUP BY COL_ NAME‏ 


COL NAME‏ هو اسم العمود في الجدول والذي سيتم تقسيم 
الجدول إلى مجموعات صغيرة بناء غليه 


ولفهم هذه الدالة ننظر الى المثال التالي 


أذ كتبنا الجملة الثالية 
SELECT id, last_name, dept id DEPARTMENT‏ 
FROM s_ emp‏ 
WHERE dept _ id = 41;‏ 


فان المخرجات هي 
ID) LAST NAME DEPARTMENT‏ 
Ngao 41‏ 2 
Urguhart 41‏ 6 
Maduro 41‏ 16 
Smith 41‏ 17 


SELECT dept id, COUNT (*) “Number” 
FROM s_ emp 

WHERE dept_id = 41 

GROUP BY dept id; 


DEPT ID Number 


نلاحظ ظهور سطر واحد من البيانات للقسم ٤١‏ فالدالة 8 6۸0۴ قامت بتجميع القسم ٤١‏ 
اظهرت ان عدد السجلات >٠‏ رغم أن عدد الاسطر هو واحد 


لاستخدام شرط مع دالة المجموعات نكتب الامر HAVING‏ 
فيكون شكل جملة الاستعلام كالاتي 


SELECT column, group_functionFROM 
table [WHERE condition] 

[GROUP BY group_by expression] [HAVING 
group_condition] 

[ORDER BY column] ; 


اذا اردنا اظهر بيانات من جدول الموظفين E۴‏ وعمل مجموعات بشرط أن تكون الوظيفة 


MANAGER 
SELECT DEPTNO, JOB, COUNT (*), SUM (SAL) 
FROM S_EMP 
GROUP BY DEPARTNO, JOB 
HAVING JOB=’ MANAGER’ ; 
مثال‎ 


اذا اردنا اظهار بیانات من جدول الموظفين EM۶‏ وعمل مجمو عات بشرط أن تكون الوظيفة 
SALESMAN /ANALYST sl MANAGER‏ 


SELECT DEPTNOy, UOBF ‘COUNT. #Yp. SUM: (SAL) 
FROM S_EMP 
GROUP BY DEPARTNO, JOB 

HAVING JOB IN ('MANAGER’,’ ANALYST’,’ SALESMAN’); 


ملأخص الفصل 


ركزنا في هذا الفصل على جمل 901 الخاصة بالدوال الرياضية والاحصائية التي تقوم بعرض 
قيمة واحدة من البيانات مثل ۷6 4, M1N‏ ,)×۸× وغیرھا ومن تم دوال المجموعات التي 
تكون غالبا مع الامر 8۷ 6200۲۴ والتي تقوم بفرز الجدول الى جدول اصغر منه أو يساويه 
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الإاستعلامات الفرعية‎ 
أهداف الفصل‎ 
في نهاية هذا الفصل ان شاء الله ستكون قادر على‎ 
تحديد الحالات التي يمكن ان تستخدم فيها الاستعلامات الفرعية‎ ١ 
کر تغرف الانتااات الف عة والتدا اة‎ 


۳- معرفة أنواع الاستعلامات الفرعية 
٤‏ كتابة استعلام فرعي احادي الصف وآخر متعدد الصفوف 


الاستعلام الفرعي 


4 


مقدمة 


لنفترض أنك تر غب في كتابة استعلام لإيجاد بيانات الموظفين الذين تزيد رواتبهم عن راتب أحد 
الموظفين 
في هذه الحالة تحتاج الى استعلامین 


-١‏ استعلام لايجاد الموظفين الذين تزيد رواتبهم عن المبلغ المحسوب في الاستعلام الأول 


ويمكنك دمج الاستعلامين وذلك بتركيب احد الاستعلامين في الاخر › الاستعلام الداخلي سوف 
إن استخدام الاستعلامات الفرعية يشبه تماما تنفيذ الاستعلامين بشكل متتال واستلام نتيجة 
الاستعلام الاول كنتيجة بحث في الاستعلام الثاني 


تعريف الاستعلام الفرعي 


نن الل ل ادنك اها فى الأستع اا سى اط الكل التانى 


SELECT...‏ الرئيسي 


الشكل العام 
SELECT select listFROM tableWHERE expr operator‏ 
(SELECT select list‏ 
FROM table),‏ 


-١‏ الاستعلام الداخلي(الفرعي) ينفذ اولا 


١ 


SELECT dept 1d SELEHLT Last name, title 
EHUM s&s emp EFE š3 ep 


THERE 1ûãst _ name='Biri '; THERE dept id = 


متطلبات الاستعلام الفرعي 


وضع الاستعلام الفرعي بين قوسين ( eT‏ ( 

لا يمکن استخدام 8۷ 0۸5٤8‏ داخل الاستعلام الفرعي 

استخدام المعاملات أحادية الصف مع الاستعلامات الفرعية الأحادية الصف 
استخدام المعاملات متعددة الصف مع الاستعلامات الفرعية المتعددة الصف 


أنواع الاستعلامات الفرعية 
يمكن تصنيف الاستعلام الفرعي حسب 
-١‏ استعلام فرعي أحادي الصف يسترجع صفا واحدا 
- استعلام فرعي متعدد الصفوف يسترجع أكثر من صف واحد 
۳- استعلام فرعي متعدد الأعمدة يسترجع اكثر من عمود 
١‏ استعلام فرعي أحادي الصف يسترجع صفا واحدا 


نستخدم هذا الاستعلام في حالة ان الاستعلام الفرعي لا يعود الا بسطر واحد انظر الى المثال 


التالي 
SELECT last_ name, title, salary‏ 
FROM s emp‏ 
WHEREsalary <‏ 
(SELECT AVG(salary)‏ 
FROM sS emp);‏ 
وسط الحسابي ويأخذ 
الاستعلام الرئيسي هذه القيمة ويستخرج اسماء وورواتب الموظفين الذين يعتبر راتبهم اعلى من 
المتوسط الحسابي 
ملاحظة 


١‏ أنواع معاملات المقارتة الخاصة بهذا النوع هي 
<> ,=< ,=> و> و< 


- استعلام فرعي متعدد الصفوف يسترجع أكثر من صف واحد 
نستخدم هذا الاستعلام في حالة ان الاستعلام الفرعي يعود بعدة اسطر انظر المثال التالي 


SELECT last_name, 
FROM s_ emp 
WHERE dept_in IN 
(SELECT 1D 
FROM S_dept 
WHERE name = 'Finance'" 
OR region id = 2); 


first_name, title 


moon 


يقوم الاستعلام الفرعي في هذا المثال ياستخراج أرقام الموظفين الذين اسمهم ' ۳1٣2٣٥٥‏ ' 
او رقم منطقتهم ۲ من جدول الاقسام فهذا الاستعلام سيعود بعدة فيم يأخذها الاستعلام الرئيسي 
ويستخرج اسماء الموظفين على اساسها 


ملاحظة 
-١‏ أنواع معاملات المقارتة الخاصة بهذا النوع هي 


IN, ALL, ANY 


۲ اذا استخدمنا معاملات الاستعلام احادي الصف مع استعلام متعدد فان البرنامج يعطيك 
رسالة خطاً 


ORA-01427:single-row sub query returns more 
than one row 


ملتك رانا 


في هذا الفصل تعرفنا على الاستعلامات الفرعية واهميتها وشروطها وانواعها الأحادية 
والمتعددة 


0 


أهداف الفصل 


في نهابة هذا الفصل ستكون قادر انشاء الله على مايلي: 
التعرف على الجداول وشروط تسميتها 
التعرف على أنواع البيانات 
إنشاء الجداول بواسطة الأمر ٣‏ 1 ٩۸٤غCR٥‏ 
إنشاء مفتاح أساسي في الجدول 
إنشاء جدول بواسطة جدول اخر 
عرض مواصفات الجدول 


تعريف الجدول 


قلنا سايقا أن الجدول أو الملف يتكون من مجموعة من السجلات E٣0R58‏ ۸ وكل سجل 
يتكون من مجمو عة من الحقول ۴18158 كل حقل به مجموعة من الحروف او الارقام وهذه 
الحقول لها طول أو عرض 


نوع بیاناته 


تسمية الجدوa/Jلف TABLE/FILE NAMES‏ 
لا يتجاوز طول اسم الجدول أو الملف عن ٠١‏ حرف 
يمكن ان يكون حروفا كبيرة او صغيرة 
الاسم يبدأ بحرف ولا يمكن أن يبدأ برقم 
يمكن أن يحتوي الاسم على رموز خاصة متل %,$,# .... الخ 
أنواع الحقول Fields Types‏ 
المتغير الحرفي C51۸8‏ 
يتكون هذا الحقل من الحروف الأبجدية »› الأرقام » والرموز الخاصة . وطول أو عرض هذا 


الحقل يصل الى ۲٤٠١‏ حرف ولا بد من تحديد طول أو عرض الحقل وهو اجباري واذا لم يتم 
التحديد سيفترض البرنامج انه ١‏ 


الشكل العام 
var CHAR (size)‏ 
مثال 
FirstName CHAR (20)‏ 
المتغیر الحرفي ۷۸R۸ C۴٤۸ R2‏ 


يتكون هذا الحقل من الحروف الأبجدية »› الأرقام » والرموز الخاصة . وطول أو عرض هذا 
الحقل يصل الى ٠٠١‏ حرف لا يوجد طول افتراضي للحقل 


مثال 
FirstName VARCHAR2 (20)‏ 


۳ متغير رقمي ص>ڍz Integer Number‏ 
ويتكون من الأرقام (0,1,2-9) والاشارة + أو _ ويمكن أن يحتوي على العلامة العشرية أو 


الفاصلة العشرية ( .) والحد الأقصى لعدد خانات الرقم يصل إلى ٠١‏ خانة وتحديد طول 
أوعرض الحقل اختياري وكذلك الاشارة أو الفاصلة العشرية 


مثال 
Serial No NUMBER (10)‏ 


> المتغير الرقمي ذو العلامة العشرية 


ويتكون من الأرقام (0,1,2-9) 


متال 
Mark NUMBER (10,3)‏ 
متغیر طویل 10٩G‏ 
يستخدم للحقول التي تحتوي على بیانات تصل مساحتها الى ۲ جيجا 
مڌال 
Detail LONG‏ 


المتغير الدال على التاريخ (ء٤04)‏ 


يتكون هذا الحقل من مجموعة الأرقام للدلالة على اليوم والشهر والسنة وطول هذا الحقل ۸ 
خانات على الأقل ويمكن أن يتغير شكل كتابة التاريخ بذكر اسم الشهر 


مذال 
HireDate DATE‏ 
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إنشاء جدول‎ 
CREATE إنشاء جدول باستخدام مر‎ 


الشكل العام 


CREATE TABLE table-name (field type [ (size [, 
field2 type [(size]); 


حيث ان 

| اسم الملف أو الجدول المطلوب‎ table-name 
انع الكل أى الكل الظاري تسام وجرد انت حل عل القن‎ field1,field2 
نوع حقل البيانات‎ type 

Size‏ ا ا 

مثال 


CREATE TABLE SCHOOL ( 
S_no NUMBER (5) NOT NULL, 
S_NAME CHAR (20). 

S_ LOC CHAR(15), 

S_DATE DATE) ; 


lلتقııد CONSTRAINT‏ 
يتم عن طريق التقييد فرض بعض القواعد على الحقول مثلا جعل حقل مفتاح أساسي 
منع ترك حقل فارغ ومن أنواعه 

NOT NULL 

UNIQUE 

PRIMARY KEY 

FORIGN KEY 


الشكل العام 


column [CONSTRAINT constraint _ name] 
constraint _ type, 


constraint name‏ اسم التقييد 
constraint type‏ نوع التقييد 


\- غر فرغ NOT NULL‏ 
هذا الأمر لا يسمح بترك حقل فارغ 
مال 
CREATE TABLE friend...‏ 
phone VARCHAR2 (15) NOT NULL,...‏ 


last_name VARCHARZ2 (25) 
CONSTRAINT friend last name nn NOT NULL,... 


UNIQUE دıرف‎ -1 


هذا الأمريجعل الحقل (العمود) فريد فلا يسمح بتكرار صف من الصفوف فكل صف لا يوجد الا 


ملاحظة 
-١‏ يمكن أن يحتوي الحقل الفرید 1۴ N1Qل‏ على قيمة فارغة بشرط أن يكون حقل واحد فقط 
فرıد UNIQUE‏ 


- وبمكن أن يوجد في الجدول أكثر حقل فريد 


مثال 


phone VARCHAR2 (10) 
CONSTRAINT s emp phone uk UNIQUE, ... 


Primary Key يسٺluصأ مفتاح‎ ۳ 

لا يمكن لأي جدول أن يحتوي الا على مفتاح أساسي واحد وإذا قمنا بتحويل حقل الى مفتاح 
أساسي فهذا الحقل يعتبر حقل فريد ولكن لا يمكن أن يحتوي على قيم فارغة 

مثال 


id NUMBER (7) 
CONSTRAINT s_ emp id pk PRIMARY KEY,... 


يمكن تعيين حقل (عمود) واحد أو أكثر ليكون مفتاح خارجي حيث يكون هذا العمود مرتبط 
بعمود اخر به مفتاح اساسي او فريد من نفس الجدول أو جدول اخر ومن الضروري أن يكون 
مرتبط بقيمة اخری من عمود اخر او یکون فارغ 


انظر المثال التالي 


moon 


dept id NUMBER (7) 
CONSTRAINT s emp dept id fk 
FOREIGN KEY (department id) 
REFERENCES s dept (id) 
ON DELETE CASCADE; 


Foreign Key -' 

تكتب بجوار ها اسم الحقل المراد أن يكون مفتاح خارجي في الجدول الابن 
REFERENCES -"‏ 

نكتب بجوارها الحقل الذي سيتم الربط به من الجدول الاخر 


ON DELETE CASCADE -‏ 
اذا تم مسح احد الصفوف في الجدول الاب سيمسح الصف المقابل له في الجدول الابن 


انشاء جدول بواسطة جدول آخر 


لإنشاء جدول بواسطة جدول آخر يجب أن يكون الجدول الآخر منشاً مسبقا ثم نكتب الأمر 


کالتالي 
الشكل العام 
CREATE TABLE tablename‏ 
[column (, column...) ]AS Select statement,‏ 
مثال 
CREATE TABLE EMPLOYEE‏ 
AS‏ 


SELECT NAME, SAL, JOB FROM S_ EMP 


قمنا في هذه الجملة بعمل جدول جديد تم نقلنا بيانات الجدول ۷۲ ع_© اليه 
انشاء جدول بواسطة استعلام فرعي 


لإنشاء جدول بواسطة استعلام فرعي يجب أن يكون الاستعلام الفرعي قائم على الاستعلام من 
جدول منشاً مسبقا ثم نكتب الأمر كالتالي 


moon 


الشكل العام 

CREATE TABLE tablename 
[column (, column...) ]AS subquery; 
مثال‎ 

CREATE TABLE emp_4 1 
AS 
SELECT id, last_ name, userid, start date 
FROM sS_emp 


WHERE dept id = 41; 


جملة عرض مواصفات جدوJ DESCIRBE‏ 
تستخدم هذه الجملة لغرض مواصفات الجدول ويمكن كتابتها كلمة كاملة أو مختصرة 5٤9€)‏ 


الشكل العام 
DESCRIBE tablename;,‏ 


متال 

DESCRIBE S_EMP, 
ملخص الفصل‎ 
في هذا الفصل قمنا بالتعرف على الجداول رانواع ل تيد وكيفية إنشاتها رإدراج المقاح‎ 


زفعرة کا هر رمات لبون 


Moon 
تعديل بنية الجدول وحذفه‎ 
أهداف الفصل‎ 
في نهاية هذا الفصل ستكون قادر ان شاء الله على:‎ 
التعرف على جميع عمليات التعديل على الجدول‎ 
إضافة حقول جديدة إلى الجدول‎ 
تل مو انات فل الجدول‎ 


حذف المفتاح الأساسي من الجدول 
حذف الجدول 


3 
- 
٣ 


تعديل الجداول 
تتيح لك ال SQ‏ عملية تعديل الجدول بعد إنشائه في الحالات التالية 
اضافة حقل جديد 
حذف المفتاح الأساسي من الجدول 
ويجب الانتباه الى عدم إمكانية حذف حقل من الجدول 


ALTER Command Jوقحنلا جملة تعديل‎ 


تستخدم هذه الجملة لإضافة حقول أو لتعديل الحقول في الجدول ويشمل هذا التعديل اسم الحقل 
ونوعه الحقل وحجم بياناته أو الحاق عبارة فارغ أو غير فارغ الى الحقل 


اضافة حقل جدیدFie[d New‏ 
الشكل العام 
ALERT TABLE tablename ADD (field Type (size) [NOT‏ 
NULL] | [NULL] )‏ 
حيث أن 
tablename‏ اسم الجدول المراد تعديله 
Type‏ نوع البيانات 
Size‏ طول أو حجم الحقل 
تعدیل مواصفات حقل 


یمکن عن طریق جملة 1۴٤ R‏ ,]۸ تعدیل مواصفات حقل 
الشكل العام 


ALERT TABLE tablename MODIFY Type (size) [NOT 
NULL] | [NULL] ) 


حذف الجداول 


يمكن أن نحذف الجدول من قاعدة البيانات بواسطة الأمر DROP 1A B٤‏ بشرط أن تكون 
مالك الجدول أو لك صلاحية للحذف 


. الشكل العام‎ 
DROP TABLE tablename, 


tablename,;‏ اسم الجدول المراد حذفه 
نكتب الأمز التالي 
ALTER TABLE tablename‏ 
DROP PRIMARY KEY CASCADE;‏ 


عبارة 5۴ )AS)4A‏ هنا لالغاء أي علاقة تعتمد على المفتاح الأساسي 


ملخص الفصل 


في هذا الفصل تناولنا عملية تعدبل الجداول من إضافة وتعديل قول الجدول مع عدم امكانية 
حذف حقل موجود في الجدول وكذلك كيفية حذف المفتاح الأساسي من الجدول وحذف الجدول 
من قاعدة البيانات بو اسطة الامر 5۸0۲ 


meen 
إدخال البيانات إلى الجداول‎ 
أهداف الفصل‎ 
إن شاء الله في نهاية هذا الفصل ستكون قادر على‎ 
الإلمام بالطرق المختلفة لإدخال البيانات إلى الجدول‎ -١ 


۲ إدخال سجل واحد إلى جدول البيانات 
اة عة لات الى الول 


إضافة بيانات 


0 


مقدمة 


لقد قمنا في الفصول السابقة بإنشاء الجداول والتعرف على أنواع البيانات وتعديل مواصفات 
الحقول وبهذا نكون قد أنشأنا جدول البيانات وحددنا خصائص الحقول من حيث نوع البيانات 
والحجم أي أننا أعددنا الوعاء الذي سيحوي البيانات وفي هذا الفصل سنتعلم بمشيئة الله كيفية 
اضافة اينات آل هذ الارن والامون المتعكة تلات الا فة وان اغها : كا ان هذا 
الفصل يشكل مدخلا وجزاً أساسيا للغة تناول البيانات (0۷) في نظام قواعد بيانات أوراكل 
التي تعتبر إحدى النظم القوية في نظم إدارة قواعد البيانات )0D(8M8(‏ لما لها من أثر فعال في 
معالجة البيانات داخل الجدول حيث تشمل لغة تناول البيانات ( M1‏ 0) على الأجزاء التالية : 


إدخال البيانات إلى انئجداوJ INSERT‏ 
تعديل البيانات في الجداول 1۴ 0۴5۸ا 
حذف البيانات من الجداول 1۴ ٥5٤ LE‏ 

في هذا الفصل سنتاناول ادخال البيانات 

إدخال البيانات إلى الجداول INSERT‏ 


هى اة ای بے ها اهال سن لات إلى درل الات ن شلال ج 15822 


أولا : إضافة سجل واحد إلى جدول البيانات 


الصيغة العامة: 

INSERT INTO table [ (columnl1 [, column2...]) ] 
VALUES (valuel [, value2...]); 

حيث أن 

Table‏ اسم الجدول المراد إلحاق السجل به 


o1 umn2‏ , 1umn1دء‏ اسماء الأعمدة(الحقول) المطلوب إدخال البيانات إليها 
7/2a1ue1, va1ue2‏ اقيم المطلوب إضافتها في 

حقول السجل الجديد وكل 

قيمة يتم إدراجها في الحقل 

الاب فى امه رهالالى 

سيتم إضلفة القيمة١‏ في الحقل 

١‏ وهكذا 


الشرح 
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د ف خد ادال دة الطر فة رفت کے شاف انات سل راک فط کے الکرل 
المذكرر بحرن على ق ت | در اجه اق حمل الخال وللكرل الكو رة فط 
القواعد التي يجب التقيد بها في هذه الطريقة 


يجب أن يكون عدد القيم التي سيتم إدخالها هو نفس عدد الحقول المذكور في جملة 
INSERT‏ 

يجب أن يكون نوع بيانات القيم التي سيتم إدخالها من نفس نوع بيانات الحقول وأن 
تكون هذه القيم مرتبة حسب ترتيب الحقول في جملة R1‏ غS؟1N‏ 


مثال 
INSERT INTO s_dept‏ 
VALUES (11, 'Finance', 2);‏ 
عند إدخال حقول التاريخ والنصوص يجب وضع القيم المدخلة بين علامتي تنصيص 
مفردتين 


يجب مراعاة وجوب إدخال قيم في الحقول الإجبارية التي تم تعريفعا على أنها لا تحتوي 
فراغ N O1 NUL‏ ویتم ادخال N01‏ في الحقول التي بھا فراغ 
مثال 
INSERT INTO S_dept‏ 
VALUES (13, 'Administration', NULL);‏ 


يجوز عدم ذكر أسماء الحقول في جملة N8٤۸1‏ في حالة إدخال بيانات جميع 
الحقول لهذا السجل على أن تكون القيم المدخلة مرتبة حسب الترتيب الافتراضي للحقول في 
الجدول عند بنائه 


ملاحظة 

لمعرفة الترتيب الافتراضي للحقول في الجدول نستخدم الأمر 0٤8€‏ 

مثال 

ثانيا : اضافة عدة سجلات إلى جدول البيانات 

من خلال هذه الطريقة يمكن ادخال أكثر من سجل واحد إلى جدول البيانات عن طريق استخدام 
متغيرات الادخال وهي عبارة عن متغيرات توضع في جملة الادخال بدلا من القيم نفسها ةيمكن 
أن نطلق على هذه الطريقة جملة الادخال متعددة السجلات 


INSERT INTO table [ (columnl1 [, column2...]) ] 
VALUES (&avariablel1l [,&svariablel ...]); 


حيث ان 

Table 
Column1,Column2 
Variablel, Variable 2 


اشح 


اسم الجدول المراد إلحاق السجل به 

اسماء الأعمدة(الحقول) المطلوب إدخال البيانات إليها 
متغیرات 

الإدخال التي 

وو 

استبدالها بقیم 

حقيقية بعد 

الادخال 


بعد تنفيذ جملة بهذه الطريقة سوف يطلب منك إدخال القيم للمتغيرات المذكورة في جملة الإدخال 
وبعد الانتهاء من ادخال القيمة تضغط مفتاح N1۳٤۸‏ من لوحة المفاتيح وهكذا حتى تنتهي من 
إدخال حقول السجل الأول ولإدخال سجل آخر يمكنك الضغط على حرف (8) تم مفتاح 
ENR‏ من لوحة المفاتيح وهو يعني تكرار الإدخال لسجلات اخرى 


مثال 


INSERT INTO s dept (id, name, 


region id) 


VALUES (&sdepartment_ id, 


‘«department_ name’, 
&region id); 


Enter value for department id: 61 
Enter value for department _ name: Accounting 


Enter value for region _ id: 2 


تنطبق على هذه الطريقة جميع القواعد المذكورة في الطريقة الأولى ويضاف إليها مايلي : 
-١‏ تستبدل القيم في جملة الإدخال بمتغيرات 
۲- يعود اختيار أسماء المتغيرات إلى المستخدم مع مراعاة شروط تسمية المتغيرات 
۳- يجب أن توضع علامة & قبل متغير الادخال 
٤‏ في جملة الإدخال يمكن وضع علامتى تنصيص مفردتين حول متغير الادخال الخاص 


بالحقول النصبة 


moon 
إضافة سجلات عن طريق نسخها من جدول آخر‎ 


من خلال هذه الطريقة يمكن إدخال أكثرمن سجل واحد إلى جدول البيانات عن طريق نسخ هذا 
السجل / السجلات من جدول آخر بواسطة جملة الاستفسار S8٤٣1‏ حيث نستخدم جملة 
N SER1‏ | مع استعلام فرعي انظر الى المثال التالي 


INSERT INTO history(id, last_ name, salary, title, 
start date) 

SELECT id, last _ name, salary,title, start date 
FROM s_ emp 

WHERE start _ date < '01-JAN-94'; 


انضرع 


بعد تنفيذ جملة الإدخال بهذه الطريقة ينم نسخ السجلات التي تحقق الشرط من الجدول | لمصدر 
إلى الجدول الهدف وللحقول االمذكورة في جملة الإدخال 


القواعد التي يجب التقيد بها في هذه الطريقة 

SELECT راسnفتسا محتوية على جملة‎ [NS ٤81 كتابة جملة الإدخال‎ ١ 

١‏ تستبدل القيم في جملة الإدخال بأسماء حقول الجدول المصدر 

۷A LU ٤8 عدم استخدم العبارة‎ ۳ 

٤‏ يجب مراعاة وجوب إدخال قيم في الحقول الاجبارية التي تم تعريفها على أنها لا تحتوي 
فرغ NOT NULL‏ 

٥‏ مطابقة الحقول بين الجدولين من حيث ترتيب الحقول ونوع البيانات وعدد الحقول 


ملخص الفصل 


تناولنا من خلال هذا الفصل موضوع اضافة البيانات إلى الجداول بواسطة جملة 1٩‏ §غS؟1NS‏ 
وهنالك ثلاثة طرق لإجراء عملية الإضافة 


أولا: إضافة سجل واحد إلى جدو ل البيانات 


بهذه الطريفة سوف يتم إضافة بيانات سجل واحد فقط إلى جدول يحتوي على القيم التي ستذكر 
في جملة الإدخال 


ثانيا : إضافة عدة سجلات إلى جدول البيانات 

بهذه الطريقة يمكن إدخال أكثر من سجل واحد إلى جدول البيانات عن طريق استخدام متغيرات 
الادخال وهي عبارة عن متغيرات توضع في جملة الإدخال بدلا من القيم نفسها ويمكن أن نطلق 
علی هذه الطريقة جملة الادخال متعددة السجلات 

ثالثا: إضافة سجلات في جدول عن طريق نسخها من جدول آخر 


بهذه الطريقة يمكن إدخال أكثر من سجل واحد إلى جدول البيانات عن طريق نسخ هذا السجل / 
السجلات من جدول آخر بواسطة جملة 951٤٣1‏ الموجودة بداخل جملة R1‏ گS؟1NS‏ 


تعديل وحذف بيانات الجداول 
أهداف الفصل 
بعد نهاية هذا الفصل ستكون ان شاء الله قادر على 
الإلمام بالطرق المختلفة لتعديل البيانات في الجدول 
إتقان تعديل بيانات سجل واحد أو أكثر في جدول البيانات 
إتقان تعديل بيانات جميع السجلات في جدول البيانات 


إتقان حذف سجل أو أكثر من جدول البيانات 
إتقان حذف جميع السجلات من جدول البيانات 


Moon 
تعديل بيانات الجدول‎ 


في هذا الفصل سنتعلم كيفية تعديل البيانات وحذف السجلات كما أن هذا الفصل يشكل جزاً 
أساسيا مكملا للغة تناول البيانات 01 في نظام أوراكل التي يعتبر احدى النظم القوية في نظم 
إدارة قواعد البيانات 088 لما لها من أثر فعال في معالجة البيانات داخل الجدول حيث 
تشتمل لغة تناول البيانات ۷1( على الاجزاء التالية 

إدخال البيانات إلى الجداول S_RT؟1NS‏ 

تعديل البيانات في الجداول 1۴ 0۴5۸ل 

حذف البيانات من الجداول ٥5٤_٤1۴‏ 


ولقد تناولنا ادخال البيانات في الفصل السابق وسندرس تعديل البيانات وحذفها في هذا الفصل 


تعديل البيانات في الجدول 


هي العملية التي يتم بها تعديل بيانات حقل / حقول في سجل واحد أو اكثر في جدول البيانات من 
خلال جملة 1۴ 0(۸ وتتم هذه العملية بطريقتين: 


أولا: تعديل بيانات حقل / حقول لسجل واحد أو اكثر 

الصيغة العامة 

UPDATE tableSET column1 = value [, column2 = 
value] 


[WHERE condition] ; 


حيث أن 


Table‏ اسم الجدول المراد تعديل البيانات فيه 
Column1,column2‏ اسماء الحقول(الاعمده) المراد تعديل بياناتها 
Value1l, value2‏ القيم الجديدة التي سيتم 

إعطاؤها للحقول (الاعمدة) 


حقل ١‏ وحقل ۲ وبالتالي 
فإن قيمة ١‏ ستؤول الى الحقل 


١‏ وهکذا 
Condition‏ جملة شرط تحدد السجلات 


التي سيتم تعديل بياناتها هي 
السجلات التي تحقق الشرط 


الشرح 

بعد تنفيذ جملة التعديل بهذه الطريقة سوف يتم تعديل بيانات الحقل /الحقول المذكورة بحيث يتم 
إلغاء القيم الموجودة فيها لتحتوي القيم الجديدة المذكورة في جملة التعديل علما بأن السجلات التي 
سيتم تعديل بياناتها هي فقط السجلات التي تحقق الشرط في الجملة الشرطية 


القواعد التي يجب التقيد بها في هذه الطريقة 
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قد تكون القيمة الجديدة عبارة عن تعبير حسابي يعتمد على قيم الحقول في الجدول 


قد تكون القيمة الجديدة ناتجة عن جملة استعلام فر عي $٤1 ٤٣1‏ 


يجب أن يكون نوع بيانات القيم الجديدة من نفس نوع بيانات الحقول التي سيتم تعديلها 


مفردتین 


يجب مراعاة وجوب إعطاء قيم للحقول التي سيتم تعديلها والتي تم تعريفها على أنها 


حقول إجبارية أي لا تحتوي فرغ NOT NULL‏ 
مثال 
S_emp‏ 
dept id = 10‏ 
id = 2;‏ 
تانيا : تعديل بيانات حقل / حقول لجميع السجلات في الجدول 
الصيغة العامة 


tableSET column1 = value [, column2 = 


الشرج 


UPDATE 
SET 
WHERE 


UPDATE 
value] 


بعد تنفيذ جملة التعديل بهذه الطريقة سوف بتم تعديل بيانات الحقل / الحقول المذكورة بحيث يتم 
إلغاء القيم الموجودة فيها لتحتوي القيم الجديدة المذكورة في جملة التعديل علما بأن السجلات التي 


سيتم تعديل بياناتها هي حميع السجلات في الجدول 


مثال 
s_emp‏ 
commission pct = 10‏ 


UPDATE 
SET 


حذف البيانات من الجداول 


هي العملية التي يتم بها حذف بيانات سجل / سجلات من جدول البيانات من خلال جملة 
DEL ٤‏ وتتم هذه العملية بطريقتين 


أول:ا خذق سكل أو أكثر من الخدذول 


الصيغة العامة 
DELETE [FROM] table[WHERE condition];‏ 


بعد تنفيذ جملة الحذف الطريقة سوف يتم حذف السجل / السجلات التي تحقق الشرط في الجملة 
الشرطية 


القواعد التي يجب التقيد بها في هذه الطريقة : 


يجب التأكد من بيانات السجلات التي سيتم حذفها قبل تنفيذ جملة الحذف وكذلك التأكد 
من الشرط في الجملة الشرطية لأن السجلات التي ستحذف تعتمد على الشرط المذكور 


تانيا: حذف جميع سجلات الجدول 


الصيغة العامة 
DELETE [FROM] table;‏ 


الشرح 


بعد تنفيذ جملة الحذف بهذه الطريقة سوف يتم حذف جميع السجلات في الجدول 
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ملخص الفصل‎ 


ران جرا ءا الل وها 


أولا تعديل بيانات حقل/ حقول لسجل واحد أو اكثر 


حيث يتم الغاء القيم الموجودة بها لتحتوي على القيم الجديدة المذكورة في جملة التعديل علما بأن 
السجلات التي سيتتم التعديل بها هي السجلان التي تحقق الشرط. 


ثانيا: تعديل بيانات حفل / حقول لجميع السجلات في الجدول 


حيث يتم الغاء القيم الموجودة بها لتحتوي على القيم الجديدة المذكورة في جملة التعديل علما انه 
سيتم تعديل بيانات جميع الحقول لعدم وجود شرط 


ثم تناولنا موضوع حذف السجلات عن٤ 5٤181‏ وهنالك طريقتان لإجراء عمليةا الحذف 
أولا: حذف سجل أو أكثر من الجدول 

بهذه الطريقة سوف يتم حذف السجل / السجلات التي تحقق الشرط في جملة الشرط 

ثانيا : حذف جميع سجلات الجدول 


بهذه الطريقة سوف يتم حذف جميع السجلات في الجدول 


المتسلسلات والفهارس والعروض 


أهداف الفصل 


معرفة الفرق بين الفهرسه التلقائية والفهرسه العادية 
عمل فهرسه للبیانات 

الغاء الفهرسه 

التعامل مع العروض ۷1ew‏ 

تکوین عرض 

تعديل العروض 

الغاء العروض 


المناادت 


كمفتاح أساسي رم رإهص1إ۴ لانها عبارة عن قيم فريده وتتعامل معها الذاكره بسهولة وبكفائه 


ال الما 


CREATE SEQUENCE name 
[INCREMENT BY n1] 
[START WITH n2] 
[ {MAXVALUE n3 | NOMAXVALUE} ] 
[{MINVALUE n4 | NOMINVALUE} ] 
[ {CYCLE | NOCYCLE} ] 
[ {CACHE n5 | NOCACHE} ] 


اسم المتسلسلة 

مقدار الزيادة كل مرة 

اول رقم تبداً منه المتسلسلة 
ادنى قيمة للمتسلسلة 

عدد الخانات في الذاكره 


السطر الاول قمنا بتعريف اسم المتسلسلة 
السطر الثاني يتم تحديد مقدار الزيادة 
السطر الثالث الرقم الذي ستبدأً منه هذه المتسلسله 
السطر الرابع نحدد اقصى قيمه تصل اليها المتسلسلة والوضع الافتراضي عدم وجود 
قيمة قصو ى٤‏ 10 ۸×۷۸ N.0M1‏ حيث يمكن للمتسلسلة ان تصل الى( ٠٠١"‏ 
للمتسلسلة التصاعديه وللتنازليه )١-(‏ 
السطر الخامس يتم تحديد ادنى قيمه للمتسلسله والوضع الافتراضي عدم وجود قيمة 
N OMآNVA LUE‏ حيث يمكن للمتسلسلة تصل الى )١(‏ في حالة المسلسلة التصاعدية 
وحالة التنازليه الى )٠١"'-(‏ 

السطر السادس ماعyع‏ یسمح بتکرارا المتسلسلة اذا وصلت الى 

أقصى قيمه وأدنى قيمه والوضع الافتراضي هو عدم التكرار 

السطر السادس يتم فيه حجز اماكن في الذاكره للمتسلسلة وذلك لسرعه التعامل مع 
المتسلسلة حيث نكتب في 5م عدد الخانات والوضوع الافتراضي أن اكون ۲١‏ واذا 
اخترنا NO)A C8٤‏ فانه لایتم حجز اماکن في الذاکره 
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مثال‎ 


CREATE SEQUENCE s dept _ id 
INCREMENT BY 1 
START WITH 51 
MAXVALUE 9999999 
NOCACHE 
NOCYCEE; 


لكي نحصل على أفضل أداء للمتسلسلة نقوم بحجز اماكن في الذاكره لأكبر عدد من المصفوفات 
نعرفه ولكن اذا ستخدمنا عدد كبير فإننا سنشغل الذاكره ونبطئ التعامل مع الجهاز واذا ستخدمنا 
عدد قليل لن يكون كافي للمتسلسله 
لذلك نستخدم مایسمی مواد الnتıلسںںڻتٽ sequence generator‏ 
۹- استخدام المتسلسلات 
اذا اردنا اضافة قيمه جديدة الى متسلسلة تستخدم 
Table name.NEXTVAL ۰‏ 
واذا اردنا القيمة الحاليه نستخدم 
Table name. CURRVAL‏ 
ولنأخذ هذا المثال 


INSERT INTO s dept (id, name, region id) 
VALUES (s dept id.NEXTVAL, ‘Finance’, 2); 


حيث قمنا بإضافة قيمه جديدة الى المتسلسلة في خانة ل¡ ثم قمنا باضافة 
finance‏ الى خانة name‏ و 2 في خlن region_id‏ 


واذا اردنا القيمة الحالية نستخدم 


SELECT s_ dept id „. CURRVAL 
FROM SYS.dual; 


لكن توجد ثغرات في المتسلسلات 
-١‏ اذا تم نقل سجل من مكان الى اخر فإانه يحدث خلل في المتسلسلة 
۲- المتسلسلة يمكن أن تستخدم في اكثر من جدول 


ت 
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تعديل متسلسلة 
يمكن تعديل مقدار الزياده أو القيمه الابتدائية للمتسلسله وتحديد اكبر وقيمه وادنى قيمه أو تغيير 
خیار التکراراو الذاکرہ عن طریق الامر ۸L1 ۴R‏ 


الصيغه العامه 


ALTER SEQUENCE sequence 
[INCREMENT BY n] 
[ {MAXVALUE n | NOMAXVALUE} ] 
[{MINVALUE n | NOMINVALUE} ] 
[{CYCLE | NOCYCLE}] 
[ {CACHE n | NOCACHE} ] 


ولكن توجد قواعد لهذا التغيير 
يجب أن تكون لك السماحية لتعديل هذه المتسلسله 
سيتم تطبيق التغيير الحادث على القيم الجديده 


اذا اردت ان يتم التغيير على جميع المتسلسلة يجب أن نقوم بمسحها اولا ثم 
اعادة انشائها 


يتم حذف متسلسلة عن طريق الأمر 5۸0۴ 
مان 


DROP SEQUENCE s dept id; 


4 


الفهرسه 
الفهرسة عبارة عن وسبلة مصممه لتسهيل الحصول على البيانات بسرعه من الجداول متثل 
الفهرس الموجود بأي كتاب فعندما نريد الوصول الى معلومة بسرعة ننظر الى الفهرس اولا 
وكذلك هو الحال في الأوراكل فعندما نقوم بفهرسة مجموعة من البيانات فاننا نستطيع الى احد 
هذه البيانات بسر عه ويتم كذلك البحث بين الجداول بسرعه ومن مميزات الفهرسه كذلك انها تقلل 
عدد البيانات المنتقله خلال وسائل الاخراج والادخال 
الترقيم العادي 
كيف تتم الفهرسة ؟ 
عندما نقوم بتعريف حقل على انه مفتاح أساسي أو اذا جعلناه حقل فريد فانه تلقائيا يفهرس 
يمكن أن نقوم بفهرسة بيانات غير فريدة لتسهيل الوصول اليها 
أنواع الفهرسة 
توجد عدة أنواع للفهرسه حيث يمكن فهرسة حقل (عمود) واحد او مجموعة من الأعمدة منها 


الفهر سة الفر يدة xعd u1niq1ue i1‏ 
هي عبارة عن قيم مفهرسة ولكن بتقييد حيث ان كل قيمة لا تتكرر الا مرة واحدة 


الفهر سة الغير ذريدö nonunique i1 dex‏ 
هي عبارة عن قيم مفهرسة ولكن بدون أي تقييد 


الفھر سة المر کب composite index‏ 
حيث يتم فهرسة عدة اعمدة حيث أن كل عمود له قيم مختلفة 


وتستخدم الفهرسة المركبه عندما تعود جملة 9٤E 1]٤٣1‏ بعدة قیم فیتم ترتيبها عن طريق 
استخدام الفهرسة المركبة 
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كيف يقوم الاوراكل بالتعامل مع الفهرسة‎ 


عندما نقوم بفهرسة حقل فإن الاوراكل يقوم بتكوين مايسمى ٤”ءصعمء ٥×‏ م1 يتم فيها تخزين 
معلومات خاصة بالفهرسة والتي تسرع الوصول الى البيانات حيث أن هذه المعلومات توضح 
أماكن السجلات وتوضح أقصر الطرق للوصول اليها عن طريق وسائل الاخرج والادخال 


والمصطلح الذي تعتمد عليه الفهرسة يسمى ×ع لم1 8*-]٥٥‏ هي عبارة عن مخطط شجري 
لمخدرعة من مرها تازا حت کم تفن الى دم تله بت مقار تتا مع ٠ك‏ القع ا 
تعلو ها وتسمى هذه الكتل branch blocks‏ وliتج‏ هذه المقارنه يتم مقارنته مع كتل اخرى الى 
أدنى درجة في هذه الكتل ويسمى و)عم[ط fه٥]‏ حيث تحتوي هذه الكتلة على كل البيانات 
المفهرسه ویوجد ما یسمی ۸0۷15 لهذه البيانات 


HII] lf 


اذا كانت البيانات فردية فإنه يوجد W1‏ ۸0 لكل قيمة ولكن اذا لمت تكن فردية فانه يمكن ان 
يتواجد أكثر من W1‏ ۸0 وفي هذه الحالة يتم ترتيبها البيانات حسب مفتاح الفهرسه ثم حسب 
ROWID‏ 
الصيغة العامة 

CREATE INDEX indexON table (column[, column]...); 
حيث أن‎ 
اسم الفھرس‎ ]nd ex 


عاab‏ اسم الجدول 
COR‏ - ا الكل المر اد قي اة 
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مثال 


CREATE INDEX s_emp_ last_ name idx 
ON s_emp (last _ name); 


عند الفهرسة يجب مراعاة مايلي 


١‏ لا نفهرس الجداول التي استعلم عنها بعدد كبير من الصفوف حيث نستخدم 
الفهرسه عندما يكون الاستعلام لا يتجاوز ١‏ % من الجدول 

۲ لا نفهرس الحقول التي يتم التعديل فيها باستمرار 

۳ لا نفهرس الجداول التي تحتوي على قيم متكررة بكثرة 
قامات رو طا م 

9 لا نفهرس غالبا الحقول التي لا تحتوي على قيم فريدة 

1 نفهرس الحقول التي تعتبر حقول رابطه بين جدول واخر 


حذف الفهرسة 
لحذف الفهرسة نستخدم الÎمر DROP INDEX‏ 
مثال 


DROP INDEX s emp last name idx; 
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العروض‎ 


العرض عبارة عن استعلام من جدول واحد أو اكثر حيث يعتبر جدول وهمي يحتوي 
على البيانات التي يأخذها من جملة S8] 8٣1‏ ولكن حقيقة ان هذا الجدول غير موجود 


ويمكن استخدم العروض في عدة مهام منها : 
بحائظ على الک فى مسري آلامان 


اخفاء تعقيد البينات عن المستخدم 
اعادة تسمية الأعمدة 


الصيغة العامة 
CREATE VIEW view-name‏ 
(columnl, ... ,columnN)‏ 
AS‏ 
select-statement‏ 
حيث أن 
view -name‏ اسم العرض 


n1صuا‏ اسم الحقول التي ستم عرضها 


مثال 


CREATE VIEW empvu45 

AS SELECT id, last _ name, title 
FROM S emp 

WHERE dept id = 45; 


3_ENMP Table 


1U Harel Warehaus z= Hanager 
24 Danas Stock Clerk 
25 Sczhmart x Stock Clerk 


ويمكنك مشاهدة المعلومات الخاصة بهذا العرض عن طریق الامر D٤9) R 18٤‏ فنكتب 


DESC empvu45; 
التحكم في مستوى الأمان‎ 


الشبكة فلذلك نقوم باضافة حقل جديد ونقيده د CK18)‏ حيث اذا كان المستخدم مدير يعطي ۷ 
واذا لم يكن يعطي N"‏ ولعمل ذلك نقوم بعدة خطوات 


او لا 
alter table S_ EMP‏ 
add‏ 
(Manager char (1) check (Manager in ('Y','N')));‏ 


update S_ EMP 

set Manager = 'N'" 
where 

ID 4= TOOL; 


meen 
ثالثا‎ 


update S_ EMP 

set Manager = 'Y' 
where 

LI: = LOOL, 


في اخر خطوتين قمنا بتحديد شرط وهو في حالة اذاكان رقم الموظف ٠٠١١‏ فانه هو المدير 
لذلك في حقل إععهمهN"‏ يعطي ۷ وغير ذلك يعطي XN‏ 


رابعا 


في هذه الخطوة والتي تليها سنقوم بإضافة حقل لاسم مستخدم حيث اسم المستخدم سيكون عبارة 
عن اول حرف من الاسم الأول للموظف بالاضافة الى اسمه الاخير 


alter table S_ EMP 
add 
(username varchar2 (31)); 


خامسا 
update S_ EMP‏ 
set username = suþbstr (first_name,1,1) ||‏ 
last_ name;‏ 

سادسا 


الان سنقوم بعمل عرض اسمه 1۸R8۷‏ 8۸_8۸ مربوط بالجدول $S_EMP‏ 


create view Re SALARY as 

select e.id, e.last_ name, e.first_ name, 
decode (s.manager,'Y¥',e.salary,null) salary 
FEOM  SEMP e; Si EMP 8 

where 

user = s.username (+); 


٣ون‏ اسم المستخدم لقاعدة البيانات الحالي لذلك قيمة هذا المتغير تعتمد على المستخدم الحالي 
للقاعدة حيث قمنا بعمل عملية ربط خارجي outer-join‏ شرطها أنه اذا کان المستخدم الحالي 
لقاعدة البيانات اسمه موجود في حقل اسماء المستخدمين في جدول الموظفين فانه يعود بقيمة في 
حقل Manager‏ اما ۲ او N‏ كما قلنا حسب رقم الموظف والدالة مل0ءم5[ تقوم مشاهدة قيمة 
Manager‏ اذا کانت ۷ فإن المستخدم مدیر وبتم عرض حقل المرتب واذا كانت N‏ لا يتم 
عرض حقل المرتب 


فلنفرض أن ل٥‏ ط۸1 هو المدير فاذا قام بكتابة الاستعلام 


فان المخرجات ستكون 


SALARY 


FIRST NAME 
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select * 


from Re Salary; 


LAST NAME 


ولكن اذا قام ×۸× بالاستعلام فإن المخرجات : 


SALARY 


FIRST NAME 


AHMED 
HERNANDEZ 
EASON 
BARRETT 
HIGGINS 
YEN 
GILROY 
CARSON 
SWANSON 


LAST NAME 


AHMED 
HERNANDEZ 
EASON 
BARRETT 
HIGGINS 
YEN 
GILROY 
CARSON 
SWANSON 


pu pup pp م نم نم م‎ 
O0O0OOOOO0OOO 
SOOO O OO OD 
OO ONUOUD WwW N pH" 
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تعديل العرض 
يتم التعديل في العرض عن طريق الامر 
11-CREATE OR REPLACE‏ 
مثال 
CREATE OR REPLACE VIEW empvu45‏ 
(id number, employee, job)‏ 
AS SELECT id, last _ name, title‏ 


FROM s_ emp 
WHERE dept id = 45; 


العرض من عرض اخر 


يمكن أن نقوم بعمل عرض من عرض اخر 


مثال 
create view EMBVY45‏ 
as‏ 
select ID, Last Name, First Name,‏ 
Middle Initial, HireDate,‏ 
from S_EMP;‏ 
حذف عرض 


لالغاء عرض نستخدم الامر 05۸0۲ 


DROP VIEW empvu45; 


ملخص الفصل 
تناولنا في هذا الفصل كيفية تكوين المتسلسلات وتعدبلها وطريقة حذفها ثم تطرقنا الى الفهرسة 


وفوائدها وانواعها وكيفية عملها وتعديلها وكذلك الغائها وفي اخر الفصل تطرقنا الى العروض 
مفهومها وفوائدها وافكارها وكيفية تعديلها والغائها 


PL/SQL نبذە‎ 


أهداف الفصل. 
١‏ التعرف على P۴1/SQ1‏ 
1 استخدام عبارة الشرط IF - THEN‏ 
۳- استخدام التكکرار 
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التعرف على ۲۴1/SQ[‏ 


هي عبارة عن كتل برمجية تشبه في في طريقة كتابتها لغة ٣‏ بالإضافة لدعمها 8Q1‏ وتحتوي 
هذه اللغة على اجراءات خاصة بها واومر مثل ۴[ وغيرها وكذلك دوال وويمكن تمثيل بنية 
البرنامج في 1/8@1 في الشكل التالي 


SIDE 
POTEET 
EIITTEUOTT 


HAPPIER UOT 
POTEET 
FIITTCIIOTT 


APPINER HOTT 
IMHOET) 


FBERKSHET 


TOG POCO 


رفن المسكن تخر بن الاأجراء قى قاعدة العاات كر داتع فر عي له أب مخد ار كاتا ماكر 
في ونام * 1و ككتله مجهولة. 


وكتلة البرتامج كمايلي؛ 
سنبدا او لا كتابة الاجراء مباشرة في ودام * 1ء وهي كمايلي: 
DECLARE‏ 
هتا ترجه تعرفاة المتغترآة والموفراة 
BEGIN‏ 
جسم البرنامج 
EXCEPTION‏ 
رموز معالجة الاخطاء 
END :‏ 
مع ملاحظة مايلي: 


ان قسم ٥۲هام‏ وقسم ۸٥ذامەء×م‏ هما اختيارين اي لايشترط وجودهما 


اي اذا كان لايو جد لديك تعریف متغیرات لاد تستخدم areاec‌ل‏ واذا کنت لان تتعامل مع الاخطاء 
'تnتخدمp excepti01‏ 
والصيغة العامة لتعريف المتغيرات في عإهإءمل 


identifier [CONSTANT] datatype [NOT NULL] 
[:= | DEFAULT expr]; 


مثال 
v_Gender CHAR (1);‏ 
v_count BINARY INTEGER := 0F‏ 
v_ total sal NUMBER(9,2) := O;‏ 
v_order date DATE := SYSDATE +t 7;‏ 
c_ tax _ rate CONSTANT NUMBER (3,2) := 8.25;‏ 
v_ valid BOOLEAN NOT NULL := TRUE;‏ 
بالإضافة الى المتغيرات التي توجد 5Q1‏ توجد هنالك متغيرات تدعمها لغة ال ا@58١۲1‏ 
BINARY_INTEGER رغتnئl -١‏ 
وتشمل الأرقام الصحيحة بین ۲.٠٤۷.٤۸۳.٦٤۷ و۲.۱٤۷.٤۸ ۳.٦ ٤۷-‏ 


PLS_INTEGER رغتnll‎ - 


وتشمل الأرقام الصحيحة بین -۷٤٩.۸۳٤.۷٤۲.۱و ۲.٠٤١.٤۸١.١٤١‏ وهذا النوع لا يشغل 
مساحة كبيرة من الذاكر ة سرع Number s BINARY _INTEGE_R ja‏ 


NATURAL -‏ 
وتشمل الارقام من ۰ الى ۲.۱٤۷.٤۸۳.٦٤۷‏ 


POSITIVE -‘“‏ 
وتشمل الارقام الموجبة فقط من ١‏ الى ۲.٠٤۷.٤۸۳.٦٤١‏ 


BOOLEAN ؟-‎ 

NULL gyi FALSE yi TRUF ةaيقll‎ Jمحي وهو متغير‎ 
%TYPE-‘ 

صمم هذا المتغير ليحمل نفس نوع البيانات التي يحملها حقل معين 


Y/%ROWTYPE -‘ 


يف المتغير المركب 
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صمم هذا المتغير ليكون متغير مركب يحمل نفس توع البيانات التي يحملها صف معين 
طريقة تعريف المتغير من النوع 1۲۷۲۴ ° 
الصيغة العامة 
variable-name table-name.column-nameSTYPE;‏ 
مثال 
v_last name s_emp.last_ nameSTYPE;‏ 


1st _ name‏ في جدول 86_۴۶ ويحتوي علی نفس القیم 


% ROWTYPE gil ù طريقة تعريف المتغير‎ 


الصيغة العامة 
variable-name table-name SROWTYPE;‏ 
مثال 
emp record s_ empSROWTYPE;‏ 
s_emp‏ 
طرق الاسناد 


مثل اذا ار دت ان تقول ان قيمة 5ز فيتم ذلك کمابلی: 
ردت ان تفول ان دي فيتم يلي 


يجب وضع النقطتين قبل = 
وف ناکد مال عل ذلك 


DBMS OUTPUT.PUT LINE !لٺمر‎ sq1 يوجد ضمن اوامر‎ 

يستخدم لكي تعرض النتيجة في وںام * اوو وهو أمر تابع ja=lزnة DBMS OUTPUT‏ 
فهذا الامر يقوم بعرض الجمل ويمكن أن يعرض كذلك التواريخ والارقام واذا اردنا ان يعرض 
انواع بیانات اخری نستخدم الامر ۸R‏ 8)_ 10 
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: والصيغة العامة له‎ 


DBMS_ OUTPUT. PUT LINE (massege) 


s86‏ هي النص او الشي الذي تريد عرضة 


ان هذا الامر لايهمك كثيرا 


.مثال : 
نريد طباعة "11۾ 1ط" على الشاشة وں‌آم * [وو يتم ذلك کمایلي: 


SET SERVEROUTPUT ON; 

BEGIN 

DBMS OUTPUT.PUT LINE CERT TRE 
End; 


السطر الاول یخبر ںام * ۹1و بأن یکتب کل مایعود به الخادم. 
ويكفي کتابته مرة واحدة عندما تدخل وںآم * 41و 


مثال اخر باستخدام المتغيرات 
Declare‏ 
number (5);‏ 1 
BEGIN‏ 
و1:=5 
DBMS OUTPUT. PU TEINEVL = IDF‏ 
END;‏ 


فائدة || الموجدة ضمن عملة الطباعة هي للوصل بين التعبيرين 


IF -THE_N عبارة الشرط‎ 


تستخدم هذه العبارة متل اي العبارت الشرطية في لغة سي او سي++ او فيجوال بيسك وغيرها 
> ولها استخدمات عديدة وسوف نعرف كيف نستخدمها مقدما مع حقول قواعد البيانات وذلك بعد 
اخذ المؤشرات 

الصيغة العامة لها كمايلي: 


IF condition THEN 


statement; ... statement; 
[ELSIF condition THEN 
statement; ... statement; ] 


[ELSIF condition THEN 


statement; ... statement; ] 
[ELSE 
statement; ... statement; ] 
END IF; 
حيث أن‎ 
هي الشرط‎ conditional 
ملاحظة‎ 


LSE‏ ۴ر ELSIF‏ اختیاریة 
ه جملة ۴[ نحنوي على عدة عبارات E151۴‏ ولكن تحتوي على عبارۃ E] S۴‏ واحدة 
انتبه الى أن طريقة کتlبi ELSEIF ٽسيلy ELS[F‏ 


ع 


Declare 

1 number (5)? 

BEGIN 

1:=5F 

IF i=5 then 

DBMS OUTPUT.PUT LINE('i = ' || 1(۶ 

ELSE 

DBMS OUTPUT.PUT LINE('iİ not eqal 5 '); 
END IF; 

END; 
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الشرط باستخدام اكثر من شرط 


Declare 

number (5); 

BEGIN 

1:=5F 

IF 1>1 then 

DEMS. OUTPUT POT LINES FO TE 

ELSIF i<1 then 

DEMS OUTPUT PUT PEENE TI FTE 

ELSIF i=1 then 

DEMS. OUTPUT, PU BINE ST Sy 
END IF; 

END; 


التكرار 
يوجد عدة اوامر للتكرار وهي: 
loop-exit-end -1‏ 
نک ان شط د 
E E E‏ 
الشرح 


السطر الثاني : تعريف متغير من نوع رقم 

السطر الثالث :البداية 

السطر الرابع : اعطاء المتغير قيمة ابتدائية وهي 1=1 
السطر الخامس : شرط الانهاء 

السطر السادس : الانهاء اذا كان 10< ولا يكمل 
السطر السابع :انها ¡f‏ 

السطر الثامن : طباعة ¡ 

السطر التاسع :زيادة قيمة ¡ بواحد 

السطر الخاشر دما ةلا 


Declare 

1 number (5); 
BEGIN 

Ll, 

LOOP 

IF 1>10 then 
EXLTL, 

END IF’; 

DBMS OUTPUT.PUT LINE ( 
1i:=i+1وF‎ 

End loop; 

END; 

/ 


وبعد كتابة هذا الكود يكون الناتج كمايلي: 


1=1 
ت 

1= 3 
1= 

1=5 
6= 1 
ت 

1 =8 
1 =9 
1=10 
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WHEN - END LOOP- EXIT -! 


1); 


Declare 

1 number (5); 
BEGIN 

و 

LOOP 

EXIT WHEN i>10; 
DBMS OUTPUT. PUT_LINE ('i 
و1:=1+1‎ 

End loop; 

END; 

/ 


ويكون الناتج نفس السابق لكن لاحظ استخدم شرط الانهاء 


WHILE - LOOP - END - 


1 


EXIT WHEN i>10; 


Declare 

1 number (5); 

BEGIN 

و 1 

WHILE i <= 10 LOOP 

DBMS OUTPUT. PUT LINE ('i 
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EEL 
End loop; 
END; 

1 


ويكون الناتج نفس المثال السابق 
FOR - IN - LOOP - END -‘‏ 


وهذه ايضا طريقة اخرى لاستخدام حلقات التكرار وهي نفس عمل اسلوب حلقات ۲ه في اي لغة 
برمجة 
والصيغة العامه لها هي على الاتي 


100۶ النهاية.. البداية‎ ۴R ¿i 1× 


الحمل المراد تكرارها 
END LOOP‏ 


متال: 
Declare‏ 
number (5);‏ 1 
BEGIN‏ 
EOR. IN 1..10 LOOP‏ 
DBMS _ OUTPUT. PUT LINE('i =' || i);‏ 
End loop;‏ 
END;‏ 
/ 
وسوف يكون الناتج كمايلي(نفس السابق): 


1= 
ا 

1 =3 
= 

1=5 
1 =6 
= 

1 =8 
1 =9 
=1 
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جملة 6010 


كما في باقي لغات البرمجة فان 6010 تنقل تسلسل عمل البرامج من نقطه الى اخرى 


100; 


الصيغة العامة 
GOTO <<my_label>>‏ 


0 


1ه_ر عنوان النقظة التي سيتم الانتقال اليها 


مڌال 

declare 

1 positive := 1; 

max loops constant positive 
begin 

وا 

Loop 

E‏ 2 ا 


If i > max loops then 
goto more processing; 
end if; 

end loop; 

<<more processing>> 

و ا 

end; 


يمكن كتابة التعليقات في 1 ٥[1/8SQ‏ بعدة طرق 
١‏ كتابة (-۔) تم التعليق 
مثال 


—— DON’T FORGET MY NAME 
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۲ كتابة )***( ثم التعلية تم )***( مرة أخرى 


مثال 
x*** DON’T FORGET MY NAME ***‏ 


٣‏ كتابة (*/) ثن التعليق ثم ( /*) مرة اخرى 
مثال 
DON’T FORGET MY NAME */‏ */ 
استخدام أوامر Q1‏ في كتل ۲P /S@Q‏ 


يمكنك استعمال جمل 5Q1‏ داخل الكتل البرمجية الخاصة ب ا۴]/8Q‏ ولكن مع وجود 


مثال 
DECLARE‏ 
max records CONSTANT int := 100;‏ 
int := 1,‏ 1 
BEGIN‏ 
FOR i IN 1..max_ records LOOP‏ 
1f (mod(i,10) = 0) then‏ 
INSERT INTO test _ table‏ 
(record number, current date)‏ 
VALUES‏ 
(i, SYSDATE);‏ 
else‏ 
NULL;‏ 
end if;‏ 
END LOOP;‏ 
COMMIT;‏ 
END;‏ 
/ 


في هذا المثال قمنا باستخدام الامر 1NS٤R1‏ و وره وهي من أوامر 8Q1‏ 


اهداف الفصل 
ق ها ها اللضل إن شاد اله كرون قار على 


١‏ التعامل مع المؤشرات الصريحه 
۲ النعامل مع المؤشرات الضمنية 


المؤشرات S088‏ ا° 


تستخدم [و/1م المؤشرات ءإموإںء لأدارة عبارات التحديد ٤ءم1مء‏ في لغة 1وو وكما لاحظنا 
الاوامر السابقة مثل ۴¡ والتكرار لم نستخدمها مع بيانات الجداول المخزنه ولعمل ذلك لابد من 
ا ف وو ت 
وهناك نوعين من المؤشرات هي الضمنية والصريحة وسوف نتطرق لك واحد بالتفصيل 
SAN, ٠‏ 


١‏ المؤشرات الصريحه ؛ 


يتم تعريف هذا النوع من المؤشرات کجزء من الاعلان ٥۲هاءمل‏ ویجب ان تشتمل عبارة [ړو 
المعرفه على عبارة التحديد {ءع[عء فقط حيث لايمكن استخدام الكلمات الاساسية 

insert,update, delete 

وعند استخدام المؤشرات الصريحه دائما ماستكتب اربعة مكونات كمايلي: 

-١‏ يتم تعريف المؤشر في الجزء عإهإءعل 

۲- يتم فتح المؤشر بعد عبارة ماعط 


الصيغة العامة لتعريف المؤشر الصريح کمايلي: 
DECLARE‏ 
CURSOR‏ اسم المؤشر 1585S‏ 
الاستعلام 


تقوم باستبدال اسم المؤشر باسم مؤشر حقيقي 
وتقوم بوضع جملة الاستعلام select‏ في مکان الاستعلام 


اسم المؤشر EN‏ 0° 


وبعد فتح المؤشر تقوم باسترجاع او تحميل البيانات سطر(سجل) واحد من المؤشر الذي تم 
تعریفه باستخدام الامر ۴۴1۳8 كمايلي: 


.......»متغيرا»متغيرا 1N10‏ اسم المؤشر ۴٤1٤۸‏ 


ومعنى هذا اي قم باسترجاع البيانات من المؤشر المعطى اسمه وحملها هام1 الى المتغيرات كع 
ملاحظة ان عدد المتغيرات يساوي عدد الحقول الموجودة في استعلام المؤشر. 
وبعد الانتهاء من اجراء العمليات على المؤشر يجب عليك اغلاقه ويتم اغلاقه كمايلي: 


meen 
close cursor name 
: مثال على طريقة تعريف مؤشر‎ 
افرض انه لدينا هذا الجدول‎ 
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اولا قم بانشاء هذا الجدول كمايلي: 


create table stud ( 
no number (4), 

name varchar2 (40), 
age number (2)); 


ثانيا قم بادخال البيانات السابقة في هذا الجدول كمايلي: 


insert into stud values (111, 'mohammed',23); 
insert into stud values (222,'talal',22); 
insert into stud values (333, 'majed',24); 


ثم قم بنتفيذ مايلي 


set serveroutput on; 

DECLARE 

name stu varchar2 (40); 

CURSOR name student IS 

select name from stud 

where no=111; 

BEGIN 

OPEN name student; 

FETCH name student INTO name stu; 
DBMS OUTPUT.PUT LINE (name stu); 
CLOSE name student; 

END; 

/ 

بعد التنفيذ سوف يظهر لك الناتج كمايلي: 
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mohammed 


وهذا الشي صحيح 
لاحظ اننا اتبعنا نفس الخطوات التي ذكرناه لكي نتعامل مع مؤشر صريح 


لاحظنا في المثال السابق ان الاستعلام في ٣0و۲ناء‏ سوف يعود بسجل واحد لكن ماذا يحدث لو 
أغاد الموئ اثر هن سكل و ارفا لمر رر على كاف السات ؟ 


لل الو لاان ات من انكام حه دما ترط ها فر فل سات الموقر ات ا 
ونعرف ذلك من خلال خاصية ل,ںم] للمؤشر كمايلي: 


foundSmycur 
هي اسم المؤشر.‎ yeu : 
ا مال اس امور هي اذ اة‎ 
خاصية التي من خلالها نعرف هل تم الانتهاء من جميع السجلات ام لا‎ fund : 
: مثال‎ 


MM 


N 3 ا‎ 
E | CS | 


نريد انشاء اجراء يقوم بالمرور على الجدول وينظر الى درجة الطالب اذا كان ناجح في المقرر 
ام لا فاذا كان )همم اكبر او يساوي ٠١۰‏ ضع قيمة عںع] في حقل اںءم] والا ضع قيمة عو[ه؟ 
في حقل )اوم۲ 


نقوم اولا بانشاء هذا الجدول : 


create table stu study ( 
NO STU number (4), 
SUBJECT varchar2 (8), 
MARK number (3), 

RESULT varchar2 (20)); 


المدخلات السابقة وبعد انشاء الجدول نقوم بادخال 


insert into stu study (NO_STU, SUBJECT, MARK) 
VAaLuêsS. (ILL; ZLOCS", SY 


insert into stu study (NO_STU, SUBJECT, MARK) 
values (222,'225CS',75); 


insert into stu _ study (NO_STU, SUBJECT, MARK) 
values (333,'225CS',40); 


بعد ذلك نقوم بانشاء الاجراء: 


declare 

mar number (3); 

no number (3); 

cursor res stu is 

select no stu,mark 

from stu _ study; 

begin 

open res _ stu; 

Loop 

fetch res stu into no,mar; 
exit when res stuSnotfound; 
1f mar>=50 then 

update stu study set result='TRUE' where 
no_stu=no; 

else 

update stu study set result='FALSE' where 
Nno_sSstu=no; 

end if; 

end loop; 

close res stu; 

end; 


/ 


وبهذا تكون النتائج في الجدول كمايلي : 
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هناك طريقة اخرى لتعريف المتغيرات لاحظ في الجدول السابق ان الحقل u؟_0م‏ تم تعريفه 
على انه من نوع ٥۲‏ ط۸ منم وتم تعريف المتغير 0م في الاجراء على انه اسنام ایضا لكي 
يتم وضع رقم الطالب فيه لكن لاحظ لو تم تغير نوع الحقل في الجدول من ۲ع اص ںام الى 

yare 12‏ فانه يجب عليك تغير نوع المتغير 0 في الاجراء ايضا لكن هناك طريقه تجعلك 
لاتعدل الاجراء كل مرة وهي استخدام الامر التالي لتعريف المتغير NO‏ في الاجراء 


typesno_stu.stu_study NO 


حیث : 
0 هي اسم المتغیر 

tudyء_tuء‏ : اسم الجدول 

uء_10‏ : الحقل المطلوب في الجدول 


%عمر) : خاصية نوع الحقل 


su _كاu‎ dy . في الجدول‎ 


وبهذا لان تقوم بتغير نوع العنصر في الاجراء في كل مرة تغير النوع وهكذا مع جميع 


المتغيرات التي لها صله بالجداول 


وبذلك يصبح الاجراء بعد التعديل كمايلي: 


declare 

mar stu _ study.mark$Stype; 
no stu study.no stuStype; 
CUESOF EOS. SEU 1S 

select no stu,mark 

from stu _ study; 

begin 

open res _ stu; 

Loop 

fetch res stu into no,mar; 


exit when res_stuSnotfound; 


LF mar>=50 then 


update stu study set result='TRUE' where 


Nno_stu=no; 
else 


update stu study set result='FALSE' where 


no _stu=no; 
end if; 
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end loop; 
CLOSE EES SEU, 
end; 


/ 


المؤشرات الضمنية 


تعرفنا سابقا على فائد المؤشرات وآامیاںء ودرسنا النوع الاول منها وفي هذا الفصل عندنا 
نوع اخر وهو المؤشرات الضمنية وهي اسهل من المؤشرات الصريحه 


وتوجد نقطتين هامتين عند التعامل مع المؤشرات الت ت 


* يظهر المؤشر الضمني في جسم الاجراء رلهط وليس في ١۲ه1ءمل‏ الخاص بالاجراء كمافي 


المؤشرات الصريحه 
* لابد ان يسترجع مؤشر {ءع[عء الضمني سطر واحد. 
اا ااه امور ال كا 
SELECT COLUM1 ,COLUM2,....... INTO‏ 
VARIABLE1 , VARIABLE2,.....‏ 


FROM table_n ame 


table name 


سوف نأخذ مثال على ذلك وسوف نستخدم الجدول الذي انشئناه سابق في الدرس الثاني عندما 
تعاملنا مع المؤشرات الصريحة وكان اسم الجدول لuاء‏ 


واردنا مثلا كتابة اجراء یقوم بحساب متوسط اعمار الطلاب ( قد يقول البعض انه لايحتاج ذلك 
الى اجراء فمجرد استخدام جملة †ءع][عء نستطيع عمل ذلك انا اقول نعم هذا صحيح لكن احب 
کک اھ ا یا و کے ری ر عن اھ ی کے رگن م ےت 
ان د ا مورت السوتة واا ی کس ت واا د 
بكتابة الاجراء كمايلي : 


Sel SEFVEFOUtEPUTE ON? 

declare 

aveage number (4,2); 

begin 

select avg (age) 

into aveage 

from stud; 

DBMS _ OUTPUT.PUT LINE (aveage) ; 
end; 


/ 


لأنفرض انه لدينا الجدولين التاليين : الجدول الاول اسمه وعوإuاهء‏ (المقررات): 


وقم بانشاء الجدول كمايلي: 


create table courses ( 
code varchar2 (8), 
course _ name varchar2 (40), 
hours number (3), 

primary key (code) ); 


وقم بادخال البيانات الموجود بالجدول كمايلي: 


insert into courses values ('216CS', 'NETWORK',3); 


insert into courses 
values ('225CS', 'ASSEMBLY',3); 


insert into courses 
values ('325CS', 'DATABASE',4); 


ثم نقوم بتكوين الجدول الثاني وهو كرلناء : 


علد 4 م 


NO_STUCOURSE_CODEMARKPOINT 
MNF OS | 
_ 222 | 2258S |75|) 


E ا‎ 
_ 111 | 2258S |90 | 
PP O 
کک‎ 


table studys ( 


create 


NO STU varchar2 (6), 


_CODE varchar?2 (8), 


COURSE 


MARK number (3), 
point number (5,2), 
primary key (NO STU, COURSE CODE)); 


يالاات الموجردة بالجول مالي ويك ادال 


into studys (NO _ STU, COURSE CODE, MARK) 
(CTILTTgT2LIOCS TOS 
into studys (NO _ STU, COURSE _ CODE, MARK) 
(CII TICS ID) 
into studys (NO _ STU, COURSE CODE, MARK) 
(C33 22C A0; 
into studys (NO _ STU, COURSE CODE, MARK) 
(TILL, 2250S ,IO); 
into studys (NO_STU, COURSE CODE, MARK) 
(CII ILOCST ETI? 


insert 
values 
insert 
values 
insert 
values 
insert 
values 
insert 
values 
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insert into studys (NO STU, COURSE _ CODE, MARK) 
values ('333','216CS',85); 


بعد الانتهاء من انشاء وادخال البيانات المطلوب انشاء اجراء يقوم بحساب عدد النقاط لكل طالب 
وفي كل مادة وهو الحقل عدد النقاط الذي لم ندخل فيه اي شيء ويجب نعلم ان : 


إه ت عي 0 د 
ل > ا e‏ ا 


ویتم حساب النقاط كمايلي : 


: 
: 
- 2 

1 


المقرر 


مثال لحساب معدل الطالب الذي رقمه ١١١‏ في المقرر 216€S‏ 


نلاحظ من جدول ورل ناء ان الطالب قد تحصل على درجة ۸۸ ونلاحظ ان الدرجة من الجدول 
السابق هي بين ۸٩ -۸١‏ وبالتالي فإن معدل الطالب في هذا المقرر هو ٠.٥‏ (وهي الطريقة 
المتبعة في اغلب الجامعات) > ومن جدولڵل وعوإuامم‏ نحصل على عدد الساعات للمقرر وبالتالي 
فان : 


عدد النقاط = ٠١.١ = ۳ * ٤.٥‏ وهكذا في جميع الطلاب وهذا هو المطلوب من الاجراء عمله. 
وبالتالي فان الاجراء سوف يكون كمايلي: 


DECLARE 

no_ Student studys.NO STUStype; 
hou courses.hours$Stype; 

mark studys.mark$Stype; 

cou_ code courses.codeStype; 
poi studys.pointStype; 

CUESOE STE POLNE 1S 
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select NO STU, COURSE CODE,MARK from studys; 
BEGIN 

open st point; 

Loop 

exit when st pointSnotfound; 
fetch st point into no Student, cou code,mark; 
select hours 

into hou 

from courses 

where code=cou_ code ; 

1f (mark>=95)and (mark<=100) then 
pOLi=5 ™ hou? 

elsif mark>=90 then 

poi:=4.75 * hou; 

elsif mark>=85 then 

poi:=4.5 * hou; 

elsif mark>=80 then 

poi:=4 * hou; 

elsif mark>=75 then 

DOLE SD ROU; 

elsif mark>=70 then 

POLE=3: *. hou; 

elsif mark>=65 then 

DOL SEZ Dr E BROUG 

elsif mark>=60 then 

poi:=2 * hou; 


else 
BDOoOL:=1L * ROU; 
end if; 


update studys set POINT=poi 

where NO STU=no Student and COURSE CODE=cou code 
end loop; 

close st point; 

end; 


/ 


لاحظ هنا اننا استخدمنا المؤشرات الصريحة والمؤشرات الضمنيه والصريحة استخدمناه لكي 
تقوم بفتح سجلات الجدول ورل ناء والمؤشر الضمنلي استخدمنا لكي يعود بعدد الساعات في كل 
مرة يدور بالحلقة. 


شرح الاجراء : 


في التعريفات اتوقع انه لاتوجد هناك مشكلة لديكم » اما جسم البرنامج ابتداً من «إزعهط فهو 
كمايلي : 


اولا يفتح المؤشر الصريح والذي يحتوي على جميع سجلات الجدول ورل داء ثم يكون حلقة 
دورانية لكي يمر على جميع سجلات الطلاب الموجودة في المؤشر الصريح وطبعا شرط الانهاء 
لهذه الحلقة هو الوصول الى اخر سجل . ثم يقوم بعملية تحديث سجلات الطالب الاولى في 
المتغيرات كمايلي: 


fetch st point into no_Student, cou_code,mark; 


وطبعا المتغيرات هي رقم الطالب ورقم المقرر والدرجة في المقرر ولنفرض الان نحن الان عند 
السجل الاول ووهو الطالب الذي رقمه ١١١‏ ورقم المقرر C8١١‏ ودرجته هي ۸۸ سوف 
يضع هذه البيانات في المتغيرات» ثم يستخدم مؤشر ضمني لكي يحضر عدد ساعات المادة التي 
درسها الطالب ١١١‏ وهي 0K8١١‏ و المؤشر هو 


select hours 

into hou 

from courses 

where code=cou_ code ; 


ومعنى هذا احضر عدد ساعات المقرر الذي رقمه هو ملهء_اهء وهذا المتغير هو معروف 

من المؤشر الصريح الاول وسبب استخدامنا هذا المؤشر هو ان عدد ساعات المقرر موجودة في 
جدول اخر ولابد من استخدام هذا المؤشر لكي يحضر عدد الساعات. وبما اننا فرضنا اننا عند 

E O‏ وهي ۳ ساعات ثم بدأ يختبر الدرجة 
cCS111‏ ھی ۸۸ وناتالی کون عدد انا کالی ک8 ۶ ۴ ٣١‏ برت الإا 

من حساب المعدل يفقوم بنعديل الجدول وتحديث قيمة ).هم بقيمتها الجديدة » وهكذا يمر على 

كل طالب بنفس الطريقة السابقة الى ان يصل الى نهاية السجلات.وبالتالي تكون النتائج كمايلي 

في الجدول ورل ناء : 


NO_STUCOURSE_CODEMARKPOINT 


IM] E | O Ma 


بعد الانتهاء من هذا المثال نكون انهينا المؤشرات بنوعيها بشكل تام وبامثله واقعيه 


المصفوفات و الاجرائيات و الدوال المخزنة 
اهداف الفصل 
سنتعلم في هذا القصل باذن الله 
١‏ ناء النة قات عامل ها 


۲ فة اء اكوا 
۳ التعامل مع الوظائف المخزنة 


الجداول في 1وء/ام ( المصفوفات) 


ت ف الكارل (الضفر قات ق ارات فى هي ل من غات ار م ل و كانت 
لديك سلسلة من الارقام وتريد تخزينها فانك تستخدم هذه الجداول للتخزين ويتم تعريف متغير من 
هذا النوع كمايلي اولا يتم تعريف هذا النوع : 


TYPE ggaill_pwl IS TABLE OF رıغڙîۃnلl_ggi‎ INDEX BY 
BINARY _ INTEGER 


غ 


DECLARE 

TYPE num array IS TABLE OF number (4) INDEX BY 
BINARY _ INTEGER; 

num num array; 

BEGIN 


لاحظ اولا تم تعریف نوع واسماہ yھ21]۲‏ 1۳0 « ثم قام بتعریف متغیر ںہ واعطاہ نوع 
num _aArray‏ وھو النوع الجديد الذي قمنا بانشاءه. 


set serveroutput on; 

DECLARE 

TYPE num array 1S TABLE OF number (4) INDEX BY 
BINARY INTEGER; 


1 number (4); 

num num array; 
BEGIN 

FOR i IN 1..10 LOOP 
num(i) := i * 1i FF 

END LOOP; 

FOR i IN 1..10 LOOP 
LEMS. OUTPUTLPUT LINE I FI Z| EF 
num(i) ); 

END LOOP; 

END; 


1 
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وويكون عمل هذا الاجراء كمايلي : الحلقة الاولى تقوم بضرب العدد ¡ في نفسه وتخزنه في 
المتغير ام برتبه 1¡ وهكذا والحلقة الثانية للطباعة ويكون الناتج كمايلي : 


1*1=1 

2*2= 4 

3*3=9 
4*4= 16 
5*5= 25 
6*6= 36 
7*[= 49 
8*8= 64 
9*9= 81 

10*10= 100 


الاجر انات الونة 


شاهدنا في الدروس الماضية ان اي اجراء نقوم بكتابة اني اذا اردت استخدامة اكثر من مرة فاني 


اقوم بكتابة كل مرة في ودام * 1وو لكي احصل على النتائج لكن ماهو رأيك لو نقوم بتخزين هذا 
الاجراء في قاعدة البيانات ونعطية اسم وحينما نحتاجه نستدعية باسمه وهذا يوفر علينا الشيء 


الكت لذلك فصلا هى الأجرائيات المخزنة 
ولكي نقوم بانشاء اجراء مخزن نقوم بمايلي : 


CREATE [OR REPLACE] PROCEDURE procedure-name 
[ (argument1 ... [, argumentN) ] IS 
[local-variable-declarations ] 

BEGIN 

executable-section 
[exception-section] 

END [procedure-name] ; 


حيث أن 


ocedure_nameام‏ اسم الاجراء المستخدم. 


0R REPLACE lal‏ فهي توضع حینما تعلم ان الاجراء موجود من السابق. 

اما عن المغيرات التي بين القوسين فهي اما متغيرات مدخله مثل اذا كان لديك اجراء حساب 
معدل طالب وتريد تمرير رقم الطالب الذي تريد حساب معدله فهذه هي تعتبر كمدخلات 
ولتعريف متغير بهذا الشكل يكون كمايلي : 


student id in number (9) 


لاحظ اسم المتغير هو إ1_اطع ل ناء ثم بعده وضعنا الكلمة م ومعنى ان هذا المتغير يعتبر 
کمدخل 


ave out number (5,2) 


مع العلم انه يمكن تعريف متغير للمدخلات والمخرجات حيث تمرر به القيمه اولا وبعد تنفيذ 
الاجراء يتم وضع القيمه في نفس المتغير وتتم كمايلي : 


ave in out number (5,2) 


ومعنى هذا اي مدخل ومخرج في نفس الوقت . 


مال ٠‏ 
في الجدول الذي قمنا بدراسته في الفصول السابقة وكان بأسم ورلu†ء‏ 


وکان كمايلي : 


| E 


لو اردنا تصميم اجراء مخزن لكي يقوم بطباعة درجة الطالب بعد تمرير رقم الطالب ورقم 
المقرر. 


الاجراء المخزن سوف يكون كمايلي : 


create or replace procedure stu _ mark ( 
stu id in studys.NO STUStype, 
cou in studys.COURSE CODEStype) 


as 
mar studys.markStype; 
begin 


select mark 

into mar 

from studys 

where NO STU=stu id 

and COURSE _ CODE=cou; 

DBMS OUTPUT.PUT LINE (mar); 
end; 
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بعد الانتهاء من تنفيد الاجراء یکون الاجراء مخزن في قاعدة البيانات ولكي نقوم باستدعاءه نقوم 
بمايلي 


begin 
stu_ mark (111, '216CS'); 
end; 


/ 


لاحظ كيف تم استدعاء الاجراء السابق من خلال اسم الاجراء وبذلك سوف يكون الناتج على 
الشاشة كمايلي 88 وهي صحيحة بعد تمرير رقم الطالب 111 ومقرر 216٣S‏ 


لكن لاحظ اننا لم نستخدم متغيرات اخراج لكن مأرايك ان نصمم اجراء اخر يقوم بنفس الوظيفة 
التي يقوم بها الاجراء السابق لكن عملية الطباعة تكون بعد الاستدعاء لكي نجعل الاجراء يقوم 
بارجاع درجة الطالب بمتغير لذلك فان الاجراء كمايلي : 


create or replace procedure stu mark22 ( 
stu _ id in studys.NO STUStype, 
cou in studys.COURSE CODEStype, 
mara out studys.markStype) 

as 

begin 

select mark 

into mara 

from studys 

where NO STU=stu id 

and COURSE _ CODE=cou; 

end; 


/ 


بعد ذلك نقوم باستدعاء الاجراء ومن ثم طباعة الدرجة لان لو لاحظت الاجراء لايقوم بالطباعة 
ولاحظ ايضا ان الدرجة تم وضعها في المتغير 21a‏ ولذلك سوف يعود بهذه القيمة وسوف 
يكون الاستدعاء كمايلي : 


declare 
m studys.markStype; 
begin 


stu_mark1 (111, '225CS',m); 
DBMS OUTPUT . PUT Line (m); 
end; 


/ 


وسوف يكون الناتج هو ٠١‏ وهذا صحيح بناء على الجدول. 


الوظائف المخزنة 


لكن الفرق ان الوظائف لابد ان تعيد قيمة 


والصسغة العامة لتكوين وظيفة كمايلي: 


CREATE [OR REPLACE] FUNCTION function-name 
[ (argument1 ... [, argumentN) ] 

RETURN function-datatype IS 
[local-variable-declarations ] 

BEGIN 

executable-section 
[exception-section] 

RETURN function-value 

END [function-name] ; 


حيٿ أن 

function_name‏ اسم الوظيفة المستخدمه. 

اما ]"EPLACE OR‏ فهي توضع حينما تعلم ان الاجراء موجود من السابق. 

اما عن المغيرات التي بين القوسين فهي اما متغيرات مدخله مثل اذا كان لديك اجراء حساب 
معدل طالب وتريد تمرير رقم الطالب الذي تريد حساب معدله فهذه هي تعتبر كمدخلات » وهي 


بنفس الطريقة التي تعاملنا بها مع الاجراءت المخزنة لاتغير على المتغيرات وطرق تعريفها.اما 
datatype RETURN‏ فهي تدل على نوع القيمة المعادة من الوظيفة . 


متل : في الجدول الذي قمنا بدراسته في الدرس الرابع وكان بأسم وول دء وكان كمايلي 


LL SS o E 


لو اردنا تصميم وظيفة ترجع بمعدل الطالب الفصل اي يتم تمرير رقم الطالب الى الوظيفة ثم يتم 
حسات اتدل انا الا 
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ويتم حساب المعدل الفصل للطالب كمايلي حمجموع النقاط + مجموع عدد الساعات لمقررات 


ولانشاء الوظيفة كمايلي : 


create or replace function stu avea(stnum in 
studys.NO STUStype) 

return real 

as 

hour courses.hoursStype; 

avrage number (4,2); 

sum hours courses.hoursStype:=0; 
point studys.POINTStype; 

total Point studys.POINTStype:=0; 
codem courses.CODEStype; 

cursor sumpoint 

1s 


OO - O U PB WW N pF 


select COURSE CODE, POINT 
from studys 
where NO STU=stnum; 


begin 

open sumpoint; 

Loop 

fetch sumpoint into codem,point; 
exit when sumpoint$notfound; 
select hours 

into hour 

from courses 

where code=codem; 

total Point:=total Pointtpoint; 
sum hours:=sum hoursthour; 

end loop; 

close sumpoint; 

avrage:=total Point/sum hours; 
return avrage; 

end; 


الشرح : 


السطر رقم :١‏ لتعريف الوظيفة 

السطر رقم :١‏ نوع القيمة التي سوف ترجع بها الوظيفة 

السطر رقم :٤‏ تعريف متغير عدد الساعات وهو نفس حقل عدد ساعات المقرر الموجودة في 
جدول ›0]S88‏ 
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الان بعد الانتهاء من شرح طريقة تصميم الوظيفة جاء دور طريقة الاستدعاء : 


لكن قبل الاستدعاء لنحسب يدويا معدل الطالب الذى رقمه ١١١‏ مثل نقار نه بالنتائج بعد 
يدود ي ر ي ر ج 
الاستعلام : 
8 


۲۷.۷١ =۱٤,۲٥۹ ۳۱۲۳,٥١ = مجموع نقاط الطالب‎ 


مجموع عدد الساعات = (عدد ساعات المقرر 08١١‏ ) + (عدد ساعات المقرر ("١‏ °8 
=+ =1 


وبالتالي فان معدل الطالب = ٤,1٣۳ =١ + ۲۷.۷١‏ 
لكن الان دعنا نستدعي الدالة ونشاهد النتائج 
SELECT distinct (NO _STU),stu_ avea(no_stu)‏ 
from studys‏ 


where no stu=111; 


لاحظ كيف تم استدعاء الدالة من خلال الاستعلام ولاحظ استخدام الدالة اعمزاءال وهي لعدم 
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NO_STU STU_AVEA(NO_STU) 


لاحظ لو كان الاستعلام بدون وجود الدالة ,)ءل فسوف يتكرر رقم الطالب عدد ظهوره في 
الجدول لذلك لوكان كمايلي : 


SELECT NO STU,stu avea (no_ stu) 


from studys 
where no stu=111; 


فان النتائج ستصبح هكذا 


NO_STU STU _AVEA (NO _ STU) 
111 4.63 
i 03 


وهذا سبب ظهور الدالة ممt1ءdi‏ 


الحزم البرمجية و الزنادات 
أهداف الفصل 
سنتناول في هذا الفصل ان شاء الله : 
-١‏ ماهية الحزم البرمجية 
۲- كيقية انشاء الحزم البرمجية ومكوناتها 
۳- ماهية الزنادات 


-٤‏ التعامل مع الزنادات 
٥‏ قوائد الزنادات 


الحزم البرمجية 


تعلمنا سابقا كيفية انشاء الاجراءت والوظائف المخزنة. لكن مارأيك لو وجد لدينا قاعدة بيانات 
كبيرة جدا ولنضرب مثال انها تحتوي على ٠١‏ اجراء او وظيفة وظيفة او اجراء لها عمل خاص 
ولنفرض ان هذه القاعدة هي لمحل تجاري ضخم يحتوي على بيانات العملاء وبيانات الموظفين 
وبانات الأضخات التجار هة ,يانات لخر ون و غير ها من يانات و ذلك قان عضن هذه 

الاخ ر أقا ت وال رظانت التخز دة مختص بااععاة مثا وة اجر اغ لحسات أحمال عسل 
وغيرها من الاجرائيات » ومثل وجود اجرئيات خاصة بالموظفين مثلا اجرائية خاصة بحساب 
راتب الموظف بعد حذف الحسومات واضافة العلاوات وغيرها ايضا » لكن وضعها في هذا 
الشكل في قاعدة البيانات قد يسسب لك بعض الارباك لذلك مارأيك بان تجمع كل الوظائف 
والاجرائيات الخاصة بكل قسم في مجموعة لوحدها وهذه المجموعة تدعي الحزمه ععج)acم‏ 
مثلا نجمع كل اجرائيات والوظائف الخاصة بالعملاء في حزمة خاصة 


فوائد استخدام الحزمة 


-١‏ تجميع وحدات [١و/ام‏ المرتبطة. 

۲ اداء افضل. 

۳- تكون السرية افضل. 

اھ ت هر کن ع الا حك ل غا الس ااام ال 


مکونات الحزم 

تتكون الحزمة من جز ءين الاول وهو الوصف ١0٥1اهءاfذءعمء‏ ويحتوي على التعاريف مثل 
ا ا ال ر كا ر م عل دا ار ت ورات و ةا 
والضية العامة لاشاء الكردالارل كمالي: 


CREATE OR REPLACE PACKAGE pack _ name AS 


والصيغة العامة لانشاء الجزء الثاني کمايلي 1 


CREATE OR REPLACE PACKAGE BODY pack name AS 


لكن يجب ان يكون اسم الحزمة في الجزء الاول هو نفس اسم الحزمة في الجزء الثاني. 
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مئال : 


ولذلك سوف نستخدم نفس الوظيفة التي انشناها في الدرس السادس والتي اسمها وع۷ج_ ناء 
والتي تقوم بحساب معدل الطالب والان نبداء بانشاء الحزمة . الجزء الاول من الحزمة 
specification‏ كمایلي : 


CREATE OR REPLACE PACKAGE student AS 
function stu _ avea(stnum in 

studys.NO STUStype)return real; 
procedure print ave (avrage in real); 
end; 


CREATE OR REPLACE PACKAGE BODY student AS 
function stu _ avea(stnum in studys.NO STUStype) 
return real 

as 

hour courses.hours$Stype; 

avrage number (4,2); 

sum hours courses.hoursStype:=0; 
point studys.POINTStype; 

total Point studys.POINTStype:=0; 
codem courses.CODEStype; 

cursor Ssumpoint 

1s 

select COURSE CODE, POINT 

from studys 

where NO STU=stnum; 

begin 

open sumpoint; 

Loop 

fetch sumpoint into codem,point; 
exit when sumpoint$Snotfound; 
select hours 

LINEORHOUE 

from courses 

where code=codem; 

total Point:=total Pointtpoint; 
sum hours:=sum hoursthour; 

end loop; 
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close sumpoint; 

avrage:=total Point/sum hours; 
return avrage; 

end; 


procedure print _ ave (avrage in real) 
as 

begin 

DBMS OUTPUT.PUT LINE (avrage); 

end; 

end; 


الحزمة حيث ان الوظيفة لحساب المعدل والاجراء لطباعة المعدل. 


طريقة استدعاء اجراء او وظيفة موجود داخل حزمة : 
تتم عملية الاستدعاء كمايلي : 

pack_name. func_proc_name 
: اي اسم الحزمة اولا ثم نقطة ثم اسم الاجراء او الوظيفة تال‎ 


set serveroutput on 
declare 

aa real; 

begin 
aa:=student.stu_ avea (111); 
student.print ave (aa) ; 
end; 


/ 


وبعد التفيذ يكون الناتج هو معدل الطالب الذي رقمه ١١١‏ لاحظ اول شي استدعينا داله حساب 
المعدل ووضعناها في المتغير هه ثم استدعينا اجراء الطباعة ليتم طبعة على الشاشة. 


والان و بعد ان تعرفت على فائدة الحزم مارأيك من الان فصاعد ان تستخدم الحزم في كتابة 
الاجرائيات والوظائف 


lلزنادlٽت TRRIGERs‏ 
تتشابه الزنادات مع البرامج الفرعية الا في الطرق التالية : 


* يتم تنفيذ الزنادات ضمنياءعندما يعدل الجدول بالرغم من عمل المستخدم او التطبيقات على 
الجدول . 


* يتم تعريف الزنادات للجدول الخاص بقاعدة البيانات 

* لاتقبل الزنادات المعاملات 

تعد الزنادات هامة جدا في تطوير نظم البيانات الموجهة الخاصة بالانتاج . 
ترکیب الزناد : 


create [or replace] Trigger <TRRIGER NAME> 
<before|after] [instead of] trigger event on <table name> 
[for Each row [whene triggering restriction]]| 

<trigger body> 


کماهو مع الاجراءات المخزنة امكانية استخدام replace‏ لکي تقوم بالتعدیل على الزناد اذا كان 
موجود ولاتقوم بانشاءه من جدید. 

ينفذ التوقيت الخاص بالزناد سواء نفذ الزناد قبل او بعد اغلاق الزناد بواسطة الخيارين عإه]٥ط‏ 
و هاگ » لكن خيار مه اكثر كفاءة لان قطع البيانات المؤثرة يجب ان تقراء منطقيا مرة 
للزناد ومرة لعبارة مع ع]٣)‏ 

ملاحظة/ ان حدث اطلاق الزناد هو جملة 1وو التي تجعل الزناد وحدث الاطلاق اما عtهلمں‏ او 
delete‏ او inset‏ او بکلیهما.. 

ويوجد اربعة انواع من الزنادات: 

af) ع٣. صف‎ -۔١‎ 

after. جملة‎ ۲ 

befor]. صف‎ ۲ 

befoإe. جملة‎ -٤ 

وکل زناد من اجل جملة عاو لمں او ٤۲٥ءہ]ً‏ او عt٥1مل‏ کل زناد یعد نوع واحد من ( dھعtیہ1ً‏ 
after, before‏ , ۴ه) ويمكن تعريف تسع زنادات للجدول الواحد.. 


* مخالكة اكات اطادق الزناة : 
او على توليفة من هذه م†م1عل او 2٤٥‏ لمں او ٤إمءمزيحتوي‏ حدث اطلاق الزناد على عملية 
العمليات عندما يتعامل زناد واحد مع اكثر من عملية واحدةء فيمكنك ان تستخدم دعائم شرطية 

للتعرف على نوع العبارة التي تستخدم لتنفيذ الجزء الخاص بالرمز في الزناد 
والدعائم هي كمايلي: 

IF inserting then .....end if; 

IF updating then .....end if; 

IF deleting then .....end if; 


قيد الزناد 


يحدد هذا القيد تعبير منطقي يجب ان يكون صحيح كي يطلق الزناد. 
على سبيل المثال الزناد التالي إمعع1٣)_‏ ٤ءء‏ لا يتم حدوثة الا اذا كان رقم الطالب 
student ¡d‏ اقل من ٠۰۰‏ 


create or replace trigger stduent trigger 
before insert or update on student 

for each row 

when(new.student id<100) 


قيود على انشاء الزنادات: 


١‏ یمکن للنص ان يحتوي على جمل 1ېو 1ہل لکن جمل †ءع[عء یجب ان تکون جمل )ءع[عو 
into‏ 

۲ لايسمح بجمJ‏ تكم commit,savepoint,ro1Iback)‏ ( 

لمكن لبر نامج فر غي مخزن ان بتضمن جمل الكهك السايةة ا تم امت غاكه برانطة الزتاد 


لنفرض انه لدينا الثلاث جداول التالية. 
الاول : هو جدول إمره[م بيانات جميع اللاعبين في النادي سواء درجة شباب او درجة ممتاز : 


حيث ۷1ع[ تمثل الدرجة التي يلعب بها اللاعب حيث ١‏ تمثل الدرجة الاولى الممتاز -و ۲ تمثل 
الشباب . 


الجدرل الي 


create table player( 

no_player varchar2(6) primary key, 
name varchar2(50), 

date_ birth date, 

phone varchar2(9), 

address varchar2(20), 

levels number@2)); 


الثاني : هو جدول اللاعبين في درجة الممتاز وهو خاص بالرواتب واسم الجدول إمرهام_ع۲ه1 


ناء ادر الي 


create table larg player( 

no_player varchar2(6) primary key, 
level no number), 

salary number(7,2)); 


الثالث : هو جدول اللاعبين في درجة الشباب وهو خاص بالرواتب واسم الجدول طااهر 


و لاء الکرل كال 


create table youth( 

no_player varchar2(6) primary key, 
level no number(2), 

salary number(7,2)); 


الان نريد عمل زناد بحيث حينما يقوم المستخدم بادخال اسم لاعب جديد وتحديد مستواه (شباب 
او ممتاز) يقوم الزناد باختبار المستوى فاذا كان شباب اضاف رقم اللاعب في جدول الشباب 
وكذلك لوكان مستواه درجة اولى الممتاز فانه يضيف رقم اللاعب في جدول إمرهام_ع۲ها 
وبذلك يكون الزناد كمايلي : 


create or replace trigger player age 

before insert on player 

for each row 

begin 

if inserting then 

if :new.levels=1 then 

insert into larg player(no_player,level no) values 
(:new.no_player,:new.levels); 

elsif :new.levels=2 then 

insert into larg player(no_player,level no) values 
(:new.no_player,:new.levels); 

end if; 

end if; 

end; 


بعد ذلك قم بادخال مايلي : 
insert into player values('1','talal','11/11/1973','123456','riyadh1',1);‏ 


لاحظ ان المدخلات تمت على جدول player‏ بعد ذلك اذهب وقما بالاستعلام في جدول 
اyeهام_عاه]‏ سوف تجد انه اضاف رقم اللاعب هناك. 


التجميعات 
انواع التجميعات في قاعدة البيانات: 
التجميعة هي مجموعة من العناصر من نفس النوع 
والتجميعات هي على نوعين: 
٠‏ التجميعة ۷2۲۲a‏ 


وهي كمصفوفة متغيرة ومشابهة للمصفوفات في اي لغة من لغات البرمجة مثل ع و++ع وتتم 
الاشارة الى اي عنصر في هذه التجميعة باستخدام الارقام السفلية ويتم التخزين في هذه 
التجميعة بصورة خطية عمناا 

nested table ةعيمجتlا‎ e 


تقر کل ج رد فیا عة تاقار الى ات عضن فى ف ااتحمة اشا 
باستخدام الارقام السفلية ويتم تخزين البيانات في جدول تخزين منفصل. 


۔اولا :التعامل مع التجمیعات فی وام اہو 
أ -التجميعة روإإوں من النوع البسيط 
مثال/ نفرض انك تريد انشاء جدول الاقسام في مستشفى والذي سوف يحتوي على رقم القسم 
> اسم القسم » واسم القسم » ومن ثم اسماء موظفين القسم .مع العلم ان اسماء الموظفين سوف 
تكون في تجميعةر ۷۵۲۲1 . 
نقوم اولا بانشاء التجميعة كمايلي: 

Create type namev as varray(30) of varchar2(50); 

/ 

حیث لو فرضنا ان ابر عدد للموظفین هو 30 واکبر طول للاسم هو 50 . 
ثم نقوم بأنشاء الجدول ونقوم بانشاءه كمايلي/ 


Create table deptv 

(nodept number (5) primary key, 
namedept varchar2 (50), 

emp namev) ; 


ونقوم فيمايلي بتنفيذبعض اوامر [يو على الجدول 
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: insert gIردں‎  -| 
Insert into deptv values(10,'medical',namev(ali','sami','fahad','fady')); 
: upd ۾٤٤ التحديث‎ ۲ 


أتحديث العناصر في التجميعة يتطلب استخدام pl/sql‏ ولايمكن تنفيذ ذلك من خلال sql‏ 


القياسية متال: 
Declare‏ 
Editname namev;‏ 
I1 number:=1;‏ 
Begin‏ 


Select emp into editname 

From deptv where nodept=10; 

LOOP 

If (i=editname.count+t1) then 

EXILE 

Elsif (editname (i)='sami') then 
Editname (i1) :='mohammed'; 

EIQ TE; 

SLE 

end loop; 

update deptv set emp=editname where nodept=10; 
end; 


شرح المثال السابق: 


سوف يقوم بتغير اسم الموظف ص هوالذي قمنا بادخال وتبديلة الى لعصصهطمص وشرح 
الخظرات گما 

اولا قمنا بتعريف متغير ٥دطه1ازلء‏ من نفس نوع التجميعة مهم وذلك لكي نقوم 
بتخزين المؤشر والذي يحتوي على اسماء الموظفين فيه ونعرف ايضامتغير 1 وهو من 


پستخدم کعداد. 


ثم نقوم بعمل مؤشر لاستخراج اسماء الموظفين وهي كمايلي 


Select emp into editname 


From deptv where nodept=10; 
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روه عكر ج اماد لر طفن للم ١‏ و تدرو ا دان فى اتير 
مصهمااله والذي هو من نفس نوع التجميعة 


O N RS O TE 
واذا لم يصل الى نهاية التجميعة يختبر عنصر التجميعة الحالي هل هو يساوي اصهء ام لا‎ 
اذا کان يساوي 2M1ويقوم بتغير هذه القيمة الى إعصصهمطمص ومن ثم يزيد العداد بواحد‎ 
ومن ثم يعود من جديد الى ان يصل الى نهاية التجميعة وبعد الانتهاء من جميع العناصر يقوم‎ 
بعمل التحديث للجدول‎ 


update deptv set emp=editname where nodept=10; 
ومن تم يقوم بانهاء الاجراء.‎ 
: delete(Trim) فذaÛl ؟-‎ 
حذف عنصر من التجميعة يتطلب عمل اجراء اپو/ام‎ 


واحد فانه يتم على اخر عنصر ولا يمكن تحديد العنصر 


مثال: 


Declare 

Namedel namev; 

Begin 

Select emp into namedel 

From deptv where nodept=10; 

Namedel.trim (1); 

update deptv set emp=namedel where nodept=10; 
end; 


/ 

update(aممءرQ( التحديث بالاضافة‎ ٤ 

هذا الامر يستخدم للاضافة 

ألم يتبادر الى ذهنك كيف نضيف مزيدا من الموظفين الى القسم ٠١‏ يمكن ان تقول نستخدم الامر 
۲ءء لكن هذا غير صحيح لاننا عندما نستخدم الامر 61۲ء1 وندخل رقم القسم ٠١‏ يظهر لنا 
خطاء لان حقل رقم القسم مفتاح رئسي 


لذلك اذا اردنا اضافة المزيد من الموظفين اولا نقوم بعمل توسع ل )»م للتجميعة لكي تسمح 
لنا باضافة عنصر جديد .ونستخدم الاجراء لذلك 


ويكون الاجراء كمايلي: 
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Declare 

Newname namev; 

Begin 

Select emp into newname 
From deptv where nodept=10; 
Newname.extend; 


Newname (newname.last) :='khaled'; 

update deptv set emp=newname where nodept=10; 
end; 

/ 


ب - التجميعة روو من النوع الشيء: 
هذه التجميعة هي تجميعة معرفة بواسطة المستخدم 
مثال ذلك ٠‏ 


لو اردنا انشاء جدول يحتوي على مسمى الوظيفة وفي حقل اخر نگون تجميعة تحتوي على 
اسم الموظف وراتبة لجميع موظفين هذه الوظيفة 


JOB NAME EMPLOYEE 
manager (ali,5000),(sami,6000),(fahad,4000) 
Analysis (lau1,7500),(mohammed,7500) 


Programming (fady,8000),(saed,6000) 


وبالتالي فان الخطوة الاولى هي انشاء مزه کمايلي 


Create type empob] 
as object (nameemp varchar2(50),salary number(6)); 
/ 
ثم نقوم بانشاء التجميعة‎ 
Create type employeeob] as varray(20) of empob]; 
/ 
لاحظ الفرق اننا استخدمنا {ءءزطه الذي انشئناه ولذلك سمي هذا النوع بهذا الاسم‎ 
وبعد انشاء التجميعة نقوم بإنشاء الجدول كمايلي:‎ 


Create table jobob] 
(job_name varchar2 (50), 


employee employeeob]); 


plus 


: الاضافة‎ ١ 


لأساف ميت إلى الجدرن البق قرم باي 


Insert into Jjobob] values 
('manager',employeeob] ( 
empobj("al1',5000), 
empobj('sami',6000), 
empobj(fahad',4000))); 
وبهذا نكون قد اضفنا الصف الاول في الجدول السابق‎ 
ولو ذهبنا الى وںام * 1ېو وطلبنا منه مايلي‎ 
Select * from jJobob] 


JOB_ NAME 


manager 


EMPLOYEE1(EMPOBJ(ali', 5000), EMPOBJ(‘sami', 6000), 
EMPOBJ(fahad', 4000)) 


ونلاحظ لقد تم اضافة الصف الجديد 


۲ التحديث ٠‏ 
يجب تطبيق قطعة 1٩و/1م‏ كمايلي: 
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Declare 
Editname employeeob],; 
Editobj empobj; 
1 number:=1; 
Begin 
Select employee into editname 
From jobob] where job_name='manager'"; 
LOOP 
Editob] :=editname (i1); 
If (i=editname.count) then 
EXILE 
Elsif editob]j.nameemp='sami' then 
Editobj.salary:=10000; 
Editname (i) :=editobj; 
End if; 
E FL 
End loop; 
Update jobob] set employee=editname 
Where job_name='manager'"; 
End; 


وبهذا يتم تعديل راتب الموظف الذي اسمه صهء الموجود في قسم manager‏ وجعل راتبه 


ono 
الحذف؛‎ ۳ 


Declare 
Editemp employeeob],; 
begin 
select Select employee into editemp 
From jobob] where job_name='manager'"; 
Editemp.trim(l1); 
Update jJobob] set employee=editemp 
Where job_name='manager'"; 


ج- التجميعة NESTED "ABLE‏ من النوع البسیط: 
تعتبر هذه التجميعة نفس التجميعة رهه من النوع البسيط والتي نقوم بتعريفها بواسطة احد 


انواع البيانات الموجودة مثل إعطصاط و 212طءإه وسوف نستخدم هنا نفس المثال الذي 
استخدمناه في التجميعة رهإإهں من النوع الشيئ . 


nested tab] eعيnجت في‎ 


اولا نقوم بانشاء التجميعة وتكون كمايلي: 


Create type namenested as table of varchar2(50); 


٣ 


ثم نقوم بأنشاء الجدول كمايلي: 


Create table deptnested 

(nodept number (5) primary key, 

namedept varchar2 (50), 

emp namenested) 

nested table emp store as nestedtablesimple; 


لاحظ السطر الاخير الذي تم اضافنته 


فيجب دائم وضعه اذا استخدمنا ع1طاها إع†وعم مع تغير المكتوب باللون الاحمر والذي يمثل 
اسم الحقل الذي هو من النو ع اطع إعايع١.‏ 


والذي تحته خط يعتبر كأسم nested table ùl‏ 


**التعامل مع الجدول السابق من خلال اوامر ايء 


: الاضافة‎ ١ 


Insert into deptnested 
values(1,'medical',namenested('ali','sami','fahad','fady')); 


: upd a) التحديث‎ ۲ 
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أتحديث العناصر في التجميعة يتطلب استخدام pl/sql‏ ولايمكن تنفيذ ذلك من خلال sql‏ 


القياسية متال: 
Declare‏ 
Editname namenested;‏ 
I1 number:=1;‏ 
Begin‏ 


Select emp into editname 

From deptnested where nodept=1; 
LOOP 
IF (i=editname.count+t1) then 
EXILE; 
Elsif (editname (i)='sami') then 
Editname (i) :='mohammed'; 

End if; 

LEE 

end loop; 
update deptnested set emp=editname where 
nodept=1; 

end; 


/ 


شرح المتال السابق: 


سوف يقوم بتغير اسم الموظف ص هوالذي قمنا بادخال وتبديلة الى لعصصهطمص وشرح 


الخطوات كمايلي 


اولا قمنا بتعريف متغير ۳٥١‏ 1114ء من نفس نوع التجميعة dعوع,ء‏ .هم وذلك لكي نقوم 
بتخزين المؤشر والذي يحتوي على اسماء الموظفين فيه ونعرف ايضا متغير 1 وهو يستخدم 


کعداد. 


ثم نقوم بعمل مؤشر لاستخراج اسماء الموظفين وهي كمايلي 


Select emp into editname 


From deptnested where nodept=1; 


moon 


يقوم هنا باستخراج اسماء الموظفين للقسم ١‏ وتخزين ناتج الاستعلام في المتغير عمصهماالم 
والذي هو من نفس نوع التجميعة 


O N RET TE 
واذا لم يصل الى نهاية التجميعة يختبر عنصر التجميعة الحالي هل هو يساوي اده ام لا‎ 
اذا کان يساوي 2M1ويقوم بتغير هذه القيمة الى إعصصهمطمص ومن ثم يزيد العداد بواحد‎ 
ومن ثم يعود من جديد الى ان يصل الى نهاية التجميعة وبعد الانتهاء من جميع العناصر يقوم‎ 
بعمل التحديث للجدول‎ 


update deptnested set emp=editname where nodept=1; 


ومن ثم يقوم بانهاء الأجراء. 


۳ التحديث بالاضافة (ل”ءممupdate)a‏ : 


اذا اردنا اضافة المزيد من الموظفين اولا نقوم بعمل توسع ل مع)×م للتجميعة لكي تسمح لنا 
باضافة عنصر جديد .ونستخدم الاجراء لذلك 


ويكون الاجراء كمايلي: 


Declare 

Newname namenested; 

Begin 

Select emp into newname 

From deptnested where nodept=1; 

Newname.extend; 

Newname (newname.last) :='khaled'; 

update deptnested set emp=newname where nodept=1; 
end; 


/ 


٤‏ -الحذف ؛ 
هناك طريقتان الاولى باستخدام n‏ وهذه الطريقة تحذف اخر صف في التجميعة ولايمكن 
اختیار اي عنصر في التجميعة: 


Declare 
Namedel namenested; 
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Begin 

Select emp into namedel 

From deptnested where nodept=1; 

Namedel.trim (1); 

update deptnested set emp=namedel where nodept=1; 
end; 


/ 


اما الطريقة الثانية فهي باستخدام الامر ( )10ء وهذه الطريقة لا تحذف من الاخير بل يتم 
اختيار اي العناصر الذي تريد حذف فلو وضعنا 2= وكانت المدخلات الجدول كما فعلا سابقا 
سیتم حذف العنصر الثاني والذي هو الموظف إصطهك 


Declare 

Namedel namenested; 

Begin 

Select emp into namedel 

From deptnested where nodept=1; 
Namedel.delete (2); 

update deptnested set emp=namedel where nodept=1; 
end; 


/ 


وهذه الطريقة(طريقة م٥1ءل)‏ هي من ابرز الفوارق بين ره۲إجv‏ و ماطه) dعاومم‏ حيث 
array‏ لا يمكنها حذف اي عنصر ولكن تحذف فقط العنصر الاخیر بعکس م[طھ) nested‏ 


د التجميعة N ESTED "ABLE‏ من النوع الشیئ: 


كما لاحظنا ان التجميعة رهه يتم انشاءها من النوع püı NESTED TABLE jl «all‏ 
إنشاءه ايضا من النوع الشيء المعرف بواسطة المستخدم. 


سوف نستخدم لشرح هذا المثال نفس المثال الذي استخدمناه في ره۲۲ه من النوع tءمزطاه‏ 


moon 


مثال ذلك ٠‏ 


لو اردنا انشاء جدول يحتوي على مسمى الوظيفة وفي حقل اخر نگون تجميعة تحتوي على 
اسماء الموظف وراتبة لجميع موظفين هذه الوظيفة 


اول خطوة هي انشاء الشيء empobj‏ والدي تم انشاءه سابق عندما قمنا بشرح vaaray‏ 
من النوع الشيء واذا كنت لم تقم بانشاءه فهذا الكود : 


Create type empob] 
as object (nameemp varchar2 (50),salary 
number (6)); 


/ 


ثاني خطوة هي إنشاء التجميعة ٥اطجا‏ لءوءعم باستخدام الشيء زطاهم ٠ء‏ كمايلي 


Create type empnestedob] as table of empob]; 
/ 


ثالث خطوة نقوم بإنشاء الجدول كمايلي: 
Create table jobnested‏ 
(job_name varchar2 (50),‏ 


employee empnestedob] ) 
nested table employee store as nestedtablesimple; 


* التعامل مع الجدول السابق من خلال اوامر اوو 


moon 
٠ الاضافة‎ ١ 


لكي تقوم بادراج بيانات في الجدول السابق نقوم بمايلي: 


Insert into jobnested 
Values ('manager'", 
empnestedob] (empob] ('ali', 6000), 
empob] ('sami', 7000), 
empob] ('fahad', 6500))); 


يتم التحديث باستخدام 1١١/1م‏ كمايلي: 
متلا لتغير راتب الموظف 1إج الموظف الاداري اي في مسمى وظيفتها إمع2مهص الى o‏ 


Declare 

Editsal empnestedob],; 

Editempob] empobj; 

1 number:=1; 

Begin 

Select employee into editsal 

From jobnested where job_name='manager'; 
LOOP 

Editempobj:=editsal (i1); 

If (i=editsal.count) then 

Exit; 

Elsif (editempob] .nameemp='fahad') then 
Editempobj.salary:=9900; 
Editsal (i1) :=editempob]); 

End if; 

e E N 

end loop; 

update jobnested set employee=editsal where 
Jjob_name='manager'; 

end; 


/ 
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۳- التحديث بالاضافة (۹رءممupd4)e)a‏ :- 


Declare 

Editemp empnestedob],; 

Begin 

Select employee into editemp 

From jobnested where job_name='manager'; 
Editemp.extend; 

Editemp (editemp.last) :=empob] ('mohammed', 7000); 
update jobnested set employee=editemp where 
Job_name='manager'; 

end; 
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: delete((rim) فزذùحٹا‎ -‘“ 


هناك طريقتان الاولى باستخدام "اا وهذه الطريقة تحذف اخر صف في التجميعة و لايمكن 
اختیار اي عنصر في التجميعة: 


declare 

empdel empnestedob]; 

begin 

Select employee into empdel 

From jobnested where job_name='manager'; 
Empdel.trim(1); 

update jobnested set employee=empdel where 
Job_name='manager'; 

end; 


/ 


اما الطريقة الثانية فهي باستخدام الامر ()عء 1ء وهذه الطريقة لا تحذف من الاخير بل يتم 
اكاز أي الخاصر الذي ترند حذف قلر وضعنا 2وو وكات المشخلات الجدول كما فعلا اقا 
سيتم حذف العنصر الثاني وهو الموظف ادم هء وفيمايلي الكود 


الطريقة الثانية 


declare 

empdel empnestedob]; 

begin 

Select employee into empdel 


From jobnested where job_name='manager'; 
Empdel.delete (2); 

update Jobnested set employee=empdel where 
Jjob_name='manager'; 

end; 


/ 


IF -THE_N عبارة الشرط‎ 


تستخدم هذه العبارة متل اي العبارت الشرطية في لغة سي او سي++ او فيجوال بيسك وغيرها 
» ولها استخدمات عديدة وسوف نعرف كيف نستخدمها مقدما مع حقول قواعد البيانات وذلك بعد 
اخذ المؤشرات 

الصيغة العامة لها كمايلي: 


IF condition THEN 


statement; ... statement; 
[ELSIF condition THEN 
statement; ... statement; ] 


[ELSIF condition THEN 


statement; ... statement; ] 
[ELSE 
statement; ... statement; ] 
END IF; 
حيث أن‎ 
هي الشرط‎ conditional 
ملاحظة‎ 


ELSIF ر٤ LSE‏ اختیاریة 
ه جملة ۴[ نحنوي على عدة عبارات E151۴‏ ولكن تحتوي على عبارۃ E1 S۴‏ واحدة 
انتبه الى أن طريقة کتlبi ELSEIF ٽسيلy ELS[F‏ 


مال غل دلت : 


Declare 
1 number (5); 
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BEGIN 

1:=D5; 

IF i1i=5 then 

DEMS OUTPUOTIPUT LINE CE FT TE 

BLSE 

DBMS OUTPUT.PUT LINE('i not eqal 5 '); 
END IF; 

END; 


الشرط باستخدام اكثر من شرط 


Declare 

۹ number (5); 

BEGIN 

=5; 

IF i>1 then 

DEMS OUTPUT. PUT TINE, ICE 

ELSIF i<1 then 

DEMS OUTPUT. PUT EINE I TE 

ELSIF i=1 then 

DEMS: OUTPUT. PUT LINE I Tag 
END IF; 

END; 


التكرار 
يوجد عدة اوامر للتكرار وهي: 
loop-exit-end -1‏ 
نک ان شط د 
E E E‏ 
الشرح 


السطر الثاني : تعريف متغير من نوع رقم 

السطر الثالث :البداية 

السطر الرابع : اعطاء المتغير قيمة ابتدائية وهي 1=1 
السطر الخامس : شرط الانهاء 

السطر السادس : الانهاء اذا كان 10< ولا يكمل 
السطر السابع :انها ¡f‏ 

السطر الثامن : طباعة ¡ 

السطر التاسع :زيادة قيمة ¡ بواحد 

السطر الخاشر دما ةلا 


Declare 

1 number (5); 
BEGIN 

Ll, 

LOOP 

IF 1>10 then 
EXLTL, 

END IF’; 

DBMS OUTPUT.PUT LINE ( 
1i:=i+1وF‎ 

End loop; 

END; 

/ 


وبعد كتابة هذا الكود يكون الناتج كمايلي: 


1=1 
ت 

1= 3 
1= 

1=5 
6= 1 
ت 

1 =8 
1 =9 
1=10 
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WHEN - END LOOP- EXIT -! 


1); 


Declare 

1 number (5); 
BEGIN 

و 

LOOP 

EXIT WHEN i>10; 
DBMS OUTPUT. PUT_LINE ('i 
و1:=1+1‎ 

End loop; 

END; 

/ 


ويكون الناتج نفس السابق لكن لاحظ استخدم شرط الانهاء 


WHILE - LOOP - END - 


1 


EXIT WHEN i>10; 


Declare 

1 number (5); 

BEGIN 

و 1 

WHILE i <= 10 LOOP 

DBMS OUTPUT. PUT LINE ('i 
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EEL 
End loop; 
END; 

1 


ويكون الناتج نفس المثال السابق 
FOR - IN - LOOP - END -‘‏ 


وهذه ايضا طريقة اخرى لاستخدام حلقات التكرار وهي نفس عمل اسلوب حلقات ۲ه في اي لغة 
برمجة 
والصيغة العامه لها هي على الاتي 


100۶ النهاية.. البداية‎ ۴R ¿i 1× 


الحمل المراد تكرارها 
END LOOP‏ 


متال: 
Declare‏ 
number (5);‏ 1 
BEGIN‏ 
EOR. IN 1..10 LOOP‏ 
DBMS _ OUTPUT. PUT LINE('i =' || i);‏ 
End loop;‏ 
END;‏ 
/ 
وسوف يكون الناتج كمايلي(نفس السابق): 


1= 
ا 

1 =3 
= 

1=5 
1 =6 
= 

1 =8 
1 =9 
=1 
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جملة 6010 


كما في باقي لغات البرمجة فان 6010 تنقل تسلسل عمل البرامج من نقطه الى اخرى 


100; 


الصيغة العامة 
GOTO <<my_label>>‏ 


0 


1ه_ر عنوان النقظة التي سيتم الانتقال اليها 


مڌال 

declare 

1 positive := 1; 

max loops constant positive 
begin 

وا 

Loop 

E‏ 2 ا 


If i > max loops then 
goto more processing; 
end if; 

end loop; 

<<more processing>> 

و ا 

end; 


يمكن كتابة التعليقات في 1 ٥[1/8SQ‏ بعدة طرق 
٤‏ كتابة (--) تم التعليق 
مثال 


—— DON’T FORGET MY NAME 
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°_ كتابة (***) تم التعليق ثم (***) مرة أخرى 


مثال 
x** DON’T FORGET MY NAME ***‏ 


كتابة (*/) ثن التعليق ثم ( /*) مرة اخرى 
مثال 
DON’T FORGET MY NAME */‏ */ 
استخدام أوامر Q1‏ في كتل ۲P /S@Q‏ 


يمكنك استعمال جمل 5Q1‏ داخل الكتل البرمجية الخاصة ب ا۴]/8Q‏ ولكن مع وجود 


مثال 
DECLARE‏ 
max records CONSTANT int := 100;‏ 
int := 1,‏ 1 
BEGIN‏ 
FOR i IN 1..max_ records LOOP‏ 
1f (mod(i,10) = 0) then‏ 
INSERT INTO test _ table‏ 
(record number, current date)‏ 
VALUES‏ 
(i, SYSDATE);‏ 
else‏ 
NULL;‏ 
end if;‏ 
END LOOP;‏ 
COMMIT;‏ 
END;‏ 
/ 


في هذا المثال قمنا باستخدام الامر 1NS٤R1‏ و وره وهي من أوامر 8Q1‏ 


اهداف الفصل 
قى ها ها اللضل إن شاد اله كرون قار على 


٣‏ التعامل مع المؤشرات الصريحه 
چ النعامل مع المؤشرات الضمنية 


المؤشرات S088‏ ا° 


تستخدم [و/1م المؤشرات ءإموإںء لأدارة عبارات التحديد ٤ءم1مء‏ في لغة 1وو وكما لاحظنا 
الاوامر السابقة مثل ۴¡ والتكرار لم نستخدمها مع بيانات الجداول المخزنه ولعمل ذلك لابد من 
اا هو وو ت 
وهناك نوعين من المؤشرات هي الضمنية والصريحة وسوف نتطرق لك واحد بالتفصيل 
e ANI, ٠‏ 


١‏ المؤشرات الصريحه ؛ 


يتم تعريف هذا النوع من المؤشرات کجزء من الاعلان ٥۲هاءمل‏ ویجب ان تشتمل عبارة [ړو 
المعرفه على عبارة التحديد {ءع[عء فقط حيث لايمكن استخدام الكلمات الاساسية 

insert,update, delete 

وعند استخدام المؤشرات الصريحه دائما ماستكتب اربعة مكونات كمايلي: 

-١‏ يتم تعريف المؤشر في الجزء عإهإءعل 

۲- يتم فتح المؤشر بعد عبارة ماعط 


الصيغة العامة لتعريف المؤشر الصريح کمايلي: 
DECLARE‏ 
CURSOR‏ اسم المؤشر 1585S‏ 
الاستعلام 


تقوم باستبدال اسم المؤشر باسم مؤشر حقيقي 
وتقوم بوضع جملة الاستعلام select‏ في مکان الاستعلام 


اسم المؤشر EN‏ 0° 


وبعد فتح المؤشر تقوم باسترجاع او تحميل البيانات سطر(سجل) واحد من المؤشر الذي تم 
تعریفه باستخدام الامر ۴۴1۳8 کكمايلي: 


.......»متغيرا»متغيرا 1N10‏ اسم المؤشر ۴٤1٤۸‏ 


ومعنى هذا اي قم باسترجاع البيانات من المؤشر المعطى اسمه وحملها هام1 الى المتغيرات كع 
ملاحظة ان عدد المتغيرات يساوي عدد الحقول الموجودة في استعلام المؤشر. 
وبعد الانتهاء من اجراء العمليات على المؤشر يجب عليك اغلاقه ويتم اغلاقه كمايلي: 


meen 
close cursor name 
: مثال على طريقة تعريف مؤشر‎ 
افرض انه لدينا هذا الجدول‎ 
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اولا قم بانشاء هذا الجدول كمايلي: 


create table stud ( 
no number (4), 

name varchar2 (40), 
age number (2)); 


ثانيا قم بادخال البيانات السابقة في هذا الجدول كمايلي: 


insert into stud values (111, 'mohammed',23); 
insert into stud values (222,'talal',22); 
insert into stud values (333, 'majed',24); 


ثم قم بنتفيذ مايلي 


set serveroutput on; 

DECLARE 

name stu varchar2 (40); 

CURSOR name student IS 

select name from stud 

where no=111; 

BEGIN 

OPEN name student; 

FETCH name student INTO name stu; 
DBMS OUTPUT.PUT LINE (name stu); 
CLOSE name student; 

END; 

/ 

بعد التنفيذ سوف يظهر لك الناتج كمايلي: 


moon 
mohammed 


وهذا الشي صحيح 
لاحظ اننا اتبعنا نفس الخطوات التي ذكرناه لكي نتعامل مع مؤشر صريح 


لاحظنا في المثال السابق ان الاستعلام في ٣0و۲ناء‏ سوف يعود بسجل واحد لكن ماذا يحدث لو 
أغاد الموئ اثر هن سكل و ارفا لمر رر على كاف السات ؟ 


لل الو لاان ات من انكام حه دما ترط ها فر فل سات الموقر ات ا 
ونعرف ذلك من خلال خاصية ل,ںم] للمؤشر كمايلي: 


foundSmycur 
هي اسم المؤشر.‎ yeu : 
ا مال اس امور هي اذ اة‎ 
خاصية التي من خلالها نعرف هل تم الانتهاء من جميع السجلات ام لا‎ fund : 
: مثال‎ 


MM 


N 3 ا‎ 
E | CS | 


نريد انشاء اجراء يقوم بالمرور على الجدول وينظر الى درجة الطالب اذا كان ناجح في المقرر 
ام لا فاذا كان )همم اكبر او يساوي ٠١۰‏ ضع قيمة عںع] في حقل اںءم] والا ضع قيمة عو[ه؟ 
في حقل )اوم۲ 


نقوم اولا بانشاء هذا الجدول : 


create table stu study ( 
NO STU number (4), 
SUBJECT varchar2 (8), 
MARK number (3), 

RESULT varchar2 (20)); 


المدخلات السابقة وبعد انشاء الجدول نقوم بادخال 


insert into stu study (NO_STU, SUBJECT, MARK) 
VAaLuêsS. (ILL; ZLOCS", SY 


insert into stu study (NO_STU, SUBJECT, MARK) 
values (222,'225CS',75); 


insert into stu _ study (NO_STU, SUBJECT, MARK) 
values (333,'225CS',40); 


بعد ذلك نقوم بانشاء الاجراء: 


declare 

mar number (3); 

no number (3); 

cursor res stu is 

select no stu,mark 

from stu _ study; 

begin 

open res _ stu; 

Loop 

fetch res stu into no,mar; 
exit when res stuSnotfound; 
1f mar>=50 then 

update stu study set result='TRUE' where 
no_stu=no; 

else 

update stu study set result='FALSE' where 
Nno_sSstu=no; 

end if; 

end loop; 

close res stu; 

end; 


/ 


وبهذا تكون النتائج في الجدول كمايلي : 
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هناك طريقة اخرى لتعريف المتغيرات لاحظ في الجدول السابق ان الحقل u؟_0م‏ تم تعريفه 
على انه من نوع ٥۲‏ ط۸ منم وتم تعريف المتغير 0م في الاجراء على انه اسنام ایضا لكي 
يتم وضع رقم الطالب فيه لكن لاحظ لو تم تغير نوع الحقل في الجدول من ۲ع اص ںام الى 

yare 12‏ فانه يجب عليك تغير نوع المتغير 0 في الاجراء ايضا لكن هناك طريقه تجعلك 
لاتعدل الاجراء كل مرة وهي استخدام الامر التالي لتعريف المتغير NO‏ في الاجراء 


typesno_stu.stu_study NO 


حیث : 
0 هي اسم المتغیر 

tudyء_tuء‏ : اسم الجدول 

uء_10‏ : الحقل المطلوب في الجدول 


%عمر) : خاصية نوع الحقل 


su _كاu‎ dy . في الجدول‎ 


وبهذا لان تقوم بتغير نوع العنصر في الاجراء في كل مرة تغير النوع وهكذا مع جميع 


المتغيرات التي لها صله بالجداول 


وبذلك يصبح الاجراء بعد التعديل كمايلي: 


declare 

mar stu _ study.mark$Stype; 
no stu study.no stuStype; 
CUESOF EOS. SEU 1S 

select no stu,mark 

from stu _ study; 

begin 

open res _ stu; 

Loop 

fetch res stu into no,mar; 


exit when res_stuSnotfound; 


LF mar>=50 then 


update stu study set result='TRUE' where 


Nno_stu=no; 
else 


update stu study set result='FALSE' where 


no _stu=no; 
end if; 
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end loop; 
CLOSE EES SEU, 
end; 


/ 


المؤشرات الضمنية 


تعرفنا سابقا على فائد المؤشرات وآامیاںء ودرسنا النوع الاول منها وفي هذا الفصل عندنا 
نوع اخر وهو المؤشرات الضمنية وهي اسهل من المؤشرات الصريحه 


وتوجد نقطتين هامتين عند التعامل مع المؤشرات الت ف 


* يظهر المؤشر الضمني في جسم الاجراء رلهط وليس في ١۲ه1ءمل‏ الخاص بالاجراء كمافي 


المؤشرات الصريحه 
* لابد ان يسترجع مؤشر {ءع[عء الضمني سطر واحد. 
اا ااه امور ال كا 
SELECT COLUM1 ,COLUM2,....... INTO‏ 
VARIABLE1 , VARIABLE2,.....‏ 


FROM table_n ame 


table name 


سوف نأخذ مثال على ذلك وسوف نستخدم الجدول الذي انشئناه سابق في الدرس الثاني عندما 


واردنا مثلا كتابة اجراء یقوم بحساب متوسط اعمار الطلاب ( قد يقول البعض انه لايحتاج ذلك 
الى اجراء فمجرد استخدام جملة )ءع][عء نستطيع عمل ذلك انا اقول نعم هذا صحيح لكن احب 
کک اھ کیا او کے ری طت کین اھ ی سے وکن م ےت 
ا فة ل المرت راق الوه و ااا ن ات واا ف 
بكتابة الاجراء كمايلي : 


Sel SEFVEFOUtEPUTE ON? 

declare 

aveage number (4,2); 

begin 

select avg (age) 

into aveage 

from stud; 

DBMS _ OUTPUT.PUT LINE (aveage) ; 
end; 


/ 


لأنفرض انه لدينا الجدولين التاليين : الجدول الاول اسمه وعوإuاهء‏ (المقررات): 


وقم بانشاء الجدول كمايلي: 


create table courses ( 
code varchar2 (8), 
course _ name varchar2 (40), 
hours number (3), 

primary key (code) ); 


وقم بادخال البيانات الموجود بالجدول كمايلي: 


insert into courses values ('216CS', 'NETWORK',3); 


insert into courses 
values ('225CS', 'ASSEMBLY',3); 


insert into courses 
values ('325CS', 'DATABASE',4); 


ثم نقوم بتكوين الجدول الثاني وهو كرلناء : 


علد 4 م 


NO_STUCOURSE_CODEMARKPOINT 
MNF OS | 
_ 222 | 2258S |75|) 


E ا‎ 
_ 111 | 2258S |90 | 
PP O 
کک‎ 


table studys ( 


create 


NO STU varchar2 (6), 


_CODE varchar?2 (8), 


COURSE 


MARK number (3), 
point number (5,2), 
primary key (NO STU, COURSE CODE)); 


يالاات الموجردة بالجول مالي ويك ادال 


into studys (NO _ STU, COURSE CODE, MARK) 
(CTILTTgT2LIOCS TOS 
into studys (NO _ STU, COURSE _ CODE, MARK) 
(CII TICS ID) 
into studys (NO _ STU, COURSE CODE, MARK) 
(C33 22C A0; 
into studys (NO _ STU, COURSE CODE, MARK) 
(TILL, 2250S ,IO); 
into studys (NO_STU, COURSE CODE, MARK) 
(CII ILOCST ETI? 


insert 
values 
insert 
values 
insert 
values 
insert 
values 
insert 
values 
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insert into studys (NO STU, COURSE _ CODE, MARK) 
values ('333','216CS',85); 


بعد الانتهاء من انشاء وادخال البيانات المطلوب انشاء اجراء يقوم بحساب عدد النقاط لكل طالب 
وفي كل مادة وهو الحقل عدد النقاط الذي لم ندخل فيه اي شيء ويجب نعلم ان : 


إه ت عي 0 د 
ل > ا e‏ ا 


ویتم حساب النقاط كمايلي : 


: 
: 
- 2 

1 


المقرر 


مثال لحساب معدل الطالب الذي رقمه ١١١‏ في المقرر 216€S‏ 


نلاحظ من جدول ورل ناء ان الطالب قد تحصل على درجة ۸۸ ونلاحظ ان الدرجة من الجدول 
السابق هي بين ۸٩ -۸١‏ وبالتالي فإن معدل الطالب في هذا المقرر هو ٠.٥‏ (وهي الطريقة 
المتبعة في اغلب الجامعات) > ومن جدولڵل وعوإuامم‏ نحصل على عدد الساعات للمقرر وبالتالي 
فان : 


عدد النقاط = ٠١.١ = ۳ * ٤.٥‏ وهكذا في جميع الطلاب وهذا هو المطلوب من الاجراء عمله. 
وبالتالي فان الاجراء سوف يكون كمايلي: 


DECLARE 

no_ Student studys.NO STUStype; 
hou courses.hours$Stype; 

mark studys.mark$Stype; 

cou_ code courses.codeStype; 
poi studys.pointStype; 

CUESOE STE POLNE 1S 


moon 


select NO STU, COURSE CODE,MARK from studys; 
BEGIN 

open st point; 

Loop 

exit when st pointSnotfound; 
fetch st point into no Student, cou code,mark; 
select hours 

into hou 

from courses 

where code=cou_ code ; 

1f (mark>=95)and (mark<=100) then 
pOLi=5 ™ hou? 

elsif mark>=90 then 

poi:=4.75 * hou; 

elsif mark>=85 then 

poi:=4.5 * hou; 

elsif mark>=80 then 

poi:=4 * hou; 

elsif mark>=75 then 

DOLE SD ROU; 

elsif mark>=70 then 

POLE=3: *. hou; 

elsif mark>=65 then 

DOL SEZ Dr E BROUG 

elsif mark>=60 then 

poi:=2 * hou; 


else 
BDOoOL:=1L * ROU; 
end if; 


update studys set POINT=poi 

where NO STU=no Student and COURSE CODE=cou code 
end loop; 

close st point; 

end; 


/ 


لاحظ هنا اننا استخدمنا المؤشرات الصريحة والمؤشرات الضمنيه والصريحة استخدمناه لكي 
تقوم بفتح سجلات الجدول ورل ناء والمؤشر الضمنلي استخدمنا لكي يعود بعدد الساعات في كل 
مرة يدور بالحلقة. 


شرح الاجراء : 


في التعريفات اتوقع انه لاتوجد هناك مشكلة لديكم » اما جسم البرنامج ابتداً من nإزعهط‏ فهو 
كمايلي : 


اولا يفتح المؤشر الصريح والذي يحتوي على جميع سجلات الجدول ورل داء ثم يكون حلقة 
دورانية لكي يمر على جميع سجلات الطلاب الموجودة في المؤشر الصريح وطبعا شرط الانهاء 
لهذه الحلقة هو الوصول الى اخر سجل . ثم يقوم بعملية تحديث سجلات الطالب الاولى في 
المتغيرات كمايلي: 


fetch st point into no_Student, cou_code,mark; 


وطبعا المتغيرات هي رقم الطالب ورقم المقرر والدرجة في المقرر ولنفرض الان نحن الان عند 
السجل الاول ووهو الطالب الذي رقمه ١١١‏ ورقم المقرر C8١١‏ ودرجته هي ۸۸ سوف 
يضع هذه البيانات في المتغيرات» ثم يستخدم مؤشر ضمني لكي يحضر عدد ساعات المادة التي 
درسها الطالب ١١١‏ وهي 0K8١١‏ و المؤشر هو 


select hours 

into hou 

from courses 

where code=cou_ code ; 


ومعنى هذا احضر عدد ساعات المقرر الذي رقمه هو ملهء_uهء‏ وهذا المتغير هو معروف 

من المؤشر الصريح الاول وسبب استخدامنا هذا المؤشر هو ان عدد ساعات المقرر موجودة في 
جدول اخر ولابد من استخدام هذا المؤشر لكي يحضر عدد الساعات. وبما اننا فرضنا اننا عند 

a‏ وهي ۳ ساعات ثم بدأ يختبر الدرجة 
cCS111‏ ھی ۸۸ اتال کون عدد اناا aT‏ 

من حساب المعدل يقوم بنعديل الجدول وتحديث قيمة ).1مم بقيمتها الجديدة » وهكذا يمر على 

كل طالب بنفس الطريقة السابقة الى ان يصل الى نهاية السجلات.وبالتالي تكون النتائج كمايلي 

في الجدول ورل ناء : 


NO_STUCOURSE_CODEMARKPOINT 
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بعد الانتهاء من هذا المثال نكون انهينا المؤشرات بنوعيها بشكل تام وبامثله واقعيه 


المصفوفات و الاجرائيات و الدوال المخزنة 
اهداف الفصل 
سنتعلم في هذا القصل باذن الله 
انشا اة قات اتال ها 


0 كيفية انشاءِ اجراء 
٦‏ ال اا اة 


الجداول في 1وء/ام ( المصفوفات) 


تف الارل تضفر ات قاقرات فى هي فة من نات ار م ل ر كانت 
لديك سلسلة من الارقام وتريد تخزينها فانك تستخدم هذه الجداول للتخزين ويتم تعريف متغير من 
هذا النوع كمايلي اولا يتم تعريف هذا النوع : 


TYPE ggaill_pwl IS TABLE OF رıغڙîۃnلl_ggi‎ INDEX BY 
BINARY _ INTEGER 


غ 


DECLARE 

TYPE num array IS TABLE OF number (4) INDEX BY 
BINARY INTEGER; 

num num array; 

BEGIN 


لاحظ اولا تم تعریف نوع واسماہ yھ21]۲‏ 1۳0 « ثم قام بتعریف متغیر ںہ واعطاہ نوع 
num _aArray‏ وھو النوع الجديد الذي قمنا بانشاءه. 


set serveroutput on; 

DECLARE 

TYPE num array 1S TABLE OF number (4) INDEX BY 
BINARY INTEGER; 


1 number (4); 

num num array; 
BEGIN 

FOR i IN 1..10 LOOP 
num(i) := i * 1i FF 

END LOOP; 

FOR i IN 1..10 LOOP 
LEMS. OUTPUTLPUT LINE I FI Z| EF 
num(i) ); 

END LOOP; 

END; 


1 
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وويكون عمل هذا الاجراء كمايلي : الحلقة الاولى تقوم بضرب العدد ¡ في نفسه وتخزنه في 
المتغير ام برتبه 1¡ وهكذا والحلقة الثانية للطباعة ويكون الناتج كمايلي : 


1*1=1 

2*2= 4 

3*3=9 
4*4= 16 
5*5= 25 
6*6= 36 
7*[= 49 
8*8= 64 
9*9= 81 

10*10= 100 


الاجر انات الونة 


شاهدنا في الدروس الماضية ان اي اجراء نقوم بكتابة اني اذا اردت استخدامة اكثر من مرة فاني 


اقوم بكتابة كل مرة في ودام * 1وو لكي احصل على النتائج لكن ماهو رأيك لو نقوم بتخزين هذا 
الاجراء في قاعدة البيانات ونعطية اسم وحينما نحتاجه نستدعية باسمه وهذا يوفر علينا الشيء 


الكتر لذلك فصلا هى الأخرائيات المخزنة 
ولكي نقوم بانشاء اجراء مخزن نقوم بمايلي : 


CREATE [OR REPLACE] PROCEDURE procedure-name 
[ (argument1 ... [, argumentN) ] IS 
[local-variable-declarations ] 

BEGIN 

executable-section 
[exception-section] 

END [procedure-name] ; 


حيث أن 


ocedure_nameام‏ اسم الاجراء المستخدم. 


اما EګREPL|AC 0R‏ فهي توضع حیينما تعلم ان الاجراء موجود من السابق. 

اما عن المغيرات التي بين القوسين فهي اما متغيرات مدخله مثل اذا كان لديك اجراء حساب 
معدل طالب وتريد تمرير رقم الطالب الذي تريد حساب معدله فهذه هي تعتبر كمدخلات 
ولتعريف متغير بهذا الشكل يكون كمايلي : 


student id in number (9) 


لاحظ اسم المتغير هو إ1_1طع ل ناء ثم بعده وضعنا الكلمة م ومعنى ان هذا المتغير يعتبر 
کمدخل 


ave out number (5,2) 


مع العلم انه يمكن تعريف متغير للمدخلات والمخرجات حيث تمرر به القيمه اولا وبعد تنفيذ 
الاجراء يتم وضع القيمه في نفس المتغير وتتم كمايلي : 


ave in out number (5,2) 


ومعنى هذا اي مدخل ومخرج في نفس الوقت . 


مال ٠‏ 
في الجدول الذي قمنا بدراسته في الفصول السابقة وكان بأسم ورلuاء‏ 


وکان كمايلي : 


| E 


لو اردنا تصميم اجراء مخزن لكي يقوم بطباعة درجة الطالب بعد تمرير رقم الطالب ورقم 
المقرر. 


الاجراء المخزن سوف يكون كمايلي : 


create or replace procedure stu _ mark ( 
stu id in studys.NO STUStype, 
cou in studys.COURSE CODEStype) 


as 
mar studys.markStype; 
begin 


select mark 

into mar 

from studys 

where NO STU=stu id 

and COURSE _ CODE=cou; 

DBMS OUTPUT.PUT LINE (mar); 
end; 
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بعد الانتهاء من تنفيد الاجراء یکون الاجراء مخزن في قاعدة البيانات ولكي نقوم باستدعاءه نقوم 
بمايلي 


begin 
stu_ mark (111, '216CS'); 
end; 


/ 


لاحظ كيف تم استدعاء الاجراء السابق من خلال اسم الاجراء وبذلك سوف يكون الناتج على 
الشاشة كمايلي 88 وهي صحيحة بعد تمرير رقم الطالب 111 ومقرر 216٣S‏ 


لكن لاحظ اننا لم نستخدم متغيرات اخراج لكن مأرايك ان نصمم اجراء اخر يقوم بنفس الوظيفة 
التي يقوم بها الاجراء السابق لكن عملية الطباعة تكون بعد الاستدعاء لكي نجعل الاجراء يقوم 
بارجاع درجة الطالب بمتغير لذلك فان الاجراء كمايلي : 


create or replace procedure stu mark22 ( 
stu _ id in studys.NO STUStype, 
cou in studys.COURSE CODEStype, 
mara out studys.markStype) 

as 

begin 

select mark 

into mara 

from studys 

where NO STU=stu id 

and COURSE _ CODE=cou; 

end; 


/ 


بعد ذلك نقوم باستدعاء الاجراء ومن ثم طباعة الدرجة لان لو لاحظت الاجراء لايقوم بالطباعة 
ولاحظ ايضا ان الدرجة تم وضعها في المتغير 21a‏ ولذلك سوف يعود بهذه القيمة وسوف 
يكون الاستدعاء كمايلي : 


declare 
m studys.markStype; 
begin 


stu_mark1 (111, '225CS',m); 
DBMS OUTPUT . PUT Line (m); 
end; 


/ 


وسوف يكون الناتج هو ٠١‏ وهذا صحيح بناء على الجدول. 


الوظائف المخزنة 


لكن الفرق ان الوظائف لابد ان تعيد قيمة 


والصسغة العامة لتكوين وظيفة كمايلي: 


CREATE [OR REPLACE] FUNCTION function-name 
[ (argument1 ... [, argumentN) ] 

RETURN function-datatype IS 
[local-variable-declarations ] 

BEGIN 

executable-section 
[exception-section] 

RETURN function-value 

END [function-name] ; 


حيٿ أن 

function_name‏ اسم الوظيفة المستخدمه. 

اما "PLACE OR‏ فهي توضع حينما تعلم ان الاجراء موجود من السابق. 

اما عن المغيرات التي بين القوسين فهي اما متغيرات مدخله مثل اذا كان لديك اجراء حساب 
معدل طالب وتريد تمرير رقم الطالب الذي تريد حساب معدله فهذه هي تعتبر كمدخلات » وهي 


بنفس الطريقة التي تعاملنا بها مع الاجراءت المخزنة لاتغير على المتغيرات وطرق تعريفها.اما 
datatype RETURN‏ فهي تدل على نوع القيمة المعادة من الوظيفة . 


متل : في الجدول الذي قمنا بدراسته في الدرس الرابع وكان بأسم وول نء وكان كمايلي 


LL SS o E 


لو اردنا تصميم وظيفة ترجع بمعدل الطالب الفصل اي يتم تمرير رقم الطالب الى الوظيفة ثم يتم 
حت ادل اانا الا 
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ويتم حساب المعدل الفصل للطالب كمايلي حمجموع النقاط + مجموع عدد الساعات لمقررات 


ولانشاء الوظيفة كمايلي : 


create or replace function stu avea(stnum in 
studys.NO STUStype) 

return real 

as 

hour courses.hoursStype; 

avrage number (4,2); 

sum hours courses.hoursStype:=0; 
point studys.POINTStype; 

total Point studys.POINTStype:=0; 
codem courses.CODEStype; 

cursor sumpoint 

1s 


OO - O U PB WW N pF 


select COURSE CODE, POINT 
from studys 
where NO STU=stnum; 


begin 

open sumpoint; 

Loop 

fetch sumpoint into codem,point; 
exit when sumpoint$notfound; 
select hours 

into hour 

from courses 

where code=codem; 

total Point:=total Pointtpoint; 
sum hours:=sum hoursthour; 

end loop; 

close sumpoint; 

avrage:=total Point/sum hours; 
return avrage; 

end; 


الشرح : 


السطر رقم :١‏ لتعريف الوظيفة 

السطر رقم :١‏ نوع القيمة التي سوف ترجع بها الوظيفة 

السطر رقم :٤‏ تعريف متغير عدد الساعات وهو نفس حقل عدد ساعات المقرر الموجودة في 
جدول ›0]S88‏ 
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الان بعد الانتهاء من شرح طريقة تصميم الوظيفة جاء دور طريقة الاستدعاء : 


لكن قبل الاستدعاء لنحسب يدويا معدل الطالب الذى رقمه ١١١‏ مثل نقار نه بالنتائج بعد 
يدود ي ر ي ر چ 
الاستعلام : 
0 


۲۷.۷١ =۱٤,۲٥۹+۳۱ ۲۳,٥١ = مجموع نقاط الطالب‎ 


مجموع عدد الساعات = (عدد ساعات المقرر 08١١‏ ) + (عدد ساعات المقرر ("٠١‏ °8 
=+ =1 


وبالتالي فان معدل الطالب = ٤,1٣۳ =١ + ۲۷.۷١‏ 
لكن الان دعنا نستدعي الدالة ونشاهد النتائج 
SELECT distinct (NO _STU),stu_ avea(no_stu)‏ 
from studys‏ 


where no stu=111; 


لاحظ كيف تم استدعاء الدالة من خلال الاستعلام ولاحظ استخدام الدالة اعمزاءال وهي لعدم 
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NO_STU STU_AVEA(NO_STU) 


لاحظ لو كان الاستعلام بدون وجود الدالة ,)ءل فسوف يتكرر رقم الطالب عدد ظهوره في 
الجدول لذلك لوكان كمايلي : 


SELECT NO STU,stu avea (no_ stu) 


from studys 
where no stu=111; 


فان النتائج ستصبح هكذا 


NO_STU STU _AVEA (NO _ STU) 
111 4.63 
i 03 


وهذا سبب ظهور الدالة ممt1ءdi‏ 


الحزم البرمجية و الزنادات 
أهداف الفصل 
سنتناول في هذا الفصل ان شاء الله : 
٦‏ ماهية الحزم البرمجية 
۷ كيقية انشاء الحزم البرمجية ومكوناتها 
۸- ماهية الزنادات 


۹- التعامل مع الزنادات 
ا قوائد الزنادات 


الحزم البرمجية 


تعلمنا سابقا كيفية انشاء الاجراءت والوظائف المخزنة. لكن مارأيك لو وجد لدينا قاعدة بيانات 
كبيرة جدا ولنضرب مثال انها تحتوي على ٠١‏ اجراء او وظيفة وظيفة او اجراء لها عمل خاص 
ولنفرض ان هذه القاعدة هي لمحل تجاري ضخم يحتوي على بيانات العملاء وبيانات الموظفين 
E yy‏ 

a mS E SE E ES Ek 

راتب الموظف بعد حذف الحسومات واضافة العلاوات وغيرها ايضا » لكن وضعها في هذا 
الشكل في قاعدة البيانات قد يسسب لك بعض الارباك لذلك مارأيك بان تجمع كل الوظائف 
والاجرائيات الخاصة بكل قسم في مجموعة لوحدها وهذه المجموعة تدعي الحزمه ععج)ءaم‏ 
مثلا نجمع كل اجرائيات والوظائف الخاصة بالعملاء في حزمة خاصة 


فوائد استخدام الحزمة 


-١‏ تجميع وحدات [١و/ام‏ المرتبطة. 

۲ اداء افضل. 

۳- تكون السرية افضل. 

اھ ی هر کن ع الا ت ل عا اا ان ال 


مکونات الحزم 

تتكون الحزمة من جز ءين الاول وهو الوصف ١٥1اهاfذءعمء‏ ويحتوي على التعاريف مثل 
ا ل ال ر سا ر ق ع ان ا ت اكات رة 
والضية الاما لاشاء الكردالارل كمالي: 


CREATE OR REPLACE PACKAGE pack _ name AS 


والصيغة العامة لانشاء الجزء الثاني کمايلي 1 


CREATE OR REPLACE PACKAGE BODY pack name AS 


لكن يجب ان يكون اسم الحزمة في الجزء الاول هو نفس اسم الحزمة في الجزء الثاني. 
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مئال : 


ولذلك سوف نستخدم نفس الوظيفة التي انشناها في الدرس السادس والتي اسمها ۵۷64_دااء 
والتي تقوم بحساب معدل الطالب والان نبداء بانشاء الحزمة . الجزء الاول من الحزمة 
specification‏ كمایلي : 


CREATE OR REPLACE PACKAGE student AS 
function stu _ avea(stnum in 

studys.NO STUStype)return real; 
procedure print ave (avrage in real); 
end; 


CREATE OR REPLACE PACKAGE BODY student AS 
function stu _ avea(stnum in studys.NO STUStype) 
return real 

as 

hour courses.hours$Stype; 

avrage number (4,2); 

sum hours courses.hoursStype:=0; 
point studys.POINTStype; 

total Point studys.POINTStype:=0; 
codem courses.CODEStype; 

cursor Ssumpoint 

1s 

select COURSE CODE, POINT 

from studys 

where NO STU=stnum; 

begin 

open sumpoint; 

Loop 

fetch sumpoint into codem,point; 
exit when sumpoint$Snotfound; 
select hours 

LINEORHOUE 

from courses 

where code=codem; 

total Point:=total Pointtpoint; 
sum hours:=sum hoursthour; 

end loop; 
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close sumpoint; 

avrage:=total Point/sum hours; 
return avrage; 

end; 


procedure print _ ave (avrage in real) 
as 

begin 

DBMS OUTPUT.PUT LINE (avrage); 

end; 

end; 


الحزمة حيث ان الوظيفة لحساب المعدل والاجراء لطباعة المعدل. 


طريقة استدعاء اجراء او وظيفة موجود داخل حزمة : 
تتم عملية الاستدعاء كمايلي : 

pack_name. func_proc_name 
: اي اسم الحزمة اولا ثم نقطة ثم اسم الاجراء او الوظيفة تال‎ 


set serveroutput on 
declare 

aa real; 

begin 
aa:=student.stu_ avea (111); 
student.print ave (aa) ; 
end; 


/ 


وبعد التفيذ يكون الناتج هو معدل الطالب الذي رقمه ١١١‏ لاحظ اول شي استدعينا داله حساب 
المعدل ووضعناها في المتغير هه ثم استدعينا اجراء الطباعة ليتم طبعة على الشاشة. 


والان و بعد ان تعرفت على فائدة الحزم مارأيك من الان فصاعد ان تستخدم الحزم في كتابة 
الاجرائيات والوظائف 


lلزنادlٽت TRRIGERs‏ 
تتشابه الزنادات مع البرامج الفرعية الا في الطرق التالية : 


* يتم تنفيذ الزنادات ضمنياءعندما يعدل الجدول بالرغم من عمل المستخدم او التطبيقات على 
الجدول . 


* يتم تعريف الزنادات للجدول الخاص بقاعدة البيانات 

* لاتقبل الزنادات المعاملات 

تعد الزنادات هامة جدا في تطوير نظم البيانات الموجهة الخاصة بالانتاج . 
ترکیب الزناد : 


create [or replace] Trigger <TRRIGER NAME> 
<before|after] [instead of] trigger event on <table name> 
[for Each row [whene triggering restriction]]| 

<trigger body> 


کماهو مع الاجراءات المخزنة امكانية استخدام replace‏ لکي تقوم بالتعدیل على الزناد اذا كان 
موجود ولاتقوم بانشاءه من جدید. 

ينفذ التوقيت الخاص بالزناد سواء نفذ الزناد قبل او بعد اغلاق الزناد بواسطة الخيارين عإه]٥ط‏ 
و هاگ » لكن خيار مه اكثر كفاءة لان قطع البيانات المؤثرة يجب ان تقراء منطقيا مرة 
للزناد ومرة لعبارة مع ع]٣)‏ 

ملاحظة/ ان حدث اطلاق الزناد هو جملة 1وو التي تجعل الزناد وحدث الاطلاق اما عtهلمں‏ او 
delete‏ او inset‏ او بکلیهما.. 

ويوجد اربعة انواع من الزنادات: 

af) ع٣. صف‎ -۔١‎ 

after. جملة‎ ۲ 

before. صف‎ ۲ 

befoإe. جملة‎ -٤ 

وکل زناد من اجل جملة عاولمں او ٤۲٥یہ]‏ او عt٥1مل‏ کل زناد یعد نوع واحد من ( dھعtیہ1ً‏ 
after, before‏ , ۴ه) ويمكن تعريف تسع زنادات للجدول الواحد.. 


* معالجة احداث اطلاق الزناد ٠‏ 
او على توليفة من هذه م†م1عل او ٥٤2لمں‏ او ٤إمءمزيحتوي‏ حدث اطلاق الزناد على عملية 
العمليات عندما يتعامل زناد واحد مع اكثر من عملية واحدةء فيمكنك ان تستخدم دعائم شرطية 

للتعرف على نوع العبارة التي تستخدم لتنفيذ الجزء الخاص بالرمز في الزناد 
والدعائم هي كمايلي: 

IF inserting then .....end if; 

IF updating then .....end if; 

IF deleting then .....end if; 


قيد الزناد 


يحدد هذا القيد تعبير منطقي يجب ان يكون صحيح كي يطلق الزناد. 
على سبيل المثال الزناد التالي إمعع٣)_‏ ٤ع‏ ناء لا يتم حدوثة الا اذا كان رقم الطالب 
student ¡d‏ اقل من ٠۰۰‏ 


create or replace trigger stduent trigger 
before insert or update on student 

for each row 

when(new.student id<100) 


قيود على انشاء الزنادات: 


١‏ یمکن للنص ان يحتوي على جمل 1ېو 1ہل لکن جمل †ءع[عء یجب ان تکون جمل )ءع[عو 
into‏ 

۲ لايسمح بجمJ‏ تكم commit,savepoint,ro1I1back)‏ ( 

لمكن لذر نامج فرعي مخزن ان بتضمن جمل التهك اة ا ت اتد عاقه برانطة الزتاد 


لنفرض انه لدينا الثلاث جداول التالية. 
الاول : هو جدول إمره[م بيانات جميع اللاعبين في النادي سواء درجة شباب او درجة ممتاز : 


حيث ۷1ع[ تمثل الدرجة التي يلعب بها اللاعب حيث ١‏ تمثل الدرجة الاولى الممتاز -و ۲ تمثل 
الشباب . 


الجدرل الي 


create table player( 

no_player varchar2(6) primary key, 
name varchar2(50), 

date_ birth date, 

phone varchar2(9), 

address varchar2(20), 

levels number@2)); 


الثاني : هو جدول اللاعبين في درجة الممتاز وهو خاص بالرواتب واسم الجدول إمرهام_ع۲ه1 


ناء ادر الي 


create table larg player( 

no_player varchar2(6) primary key, 
level no number), 

salary number(7,2)); 


الثالث : هو جدول اللاعبين في درجة الشباب وهو خاص بالرواتب واسم الجدول طااهر 


و لاء الکرل كال 


create table youth( 

no_player varchar2(6) primary key, 
level no number(2), 

salary number(7,2)); 


الان نريد عمل زناد بحيث حينما يقوم المستخدم بادخال اسم لاعب جديد وتحديد مستواه (شباب 
او ممتاز) يقوم الزناد باختبار المستوى فاذا كان شباب اضاف رقم اللاعب في جدول الشباب 
وكذلك لوكان مستواه درجة اولى الممتاز فانه يضيف رقم اللاعب في جدول إمرهام_ع۲ها 
وبذلك يكون الزناد كمايلي : 


create or replace trigger player age 

before insert on player 

for each row 

begin 

if inserting then 

if :new.levels=1 then 

insert into larg player(no_player,level no) values 
(:new.no_player,:new.levels); 

elsif :new.levels=2 then 

insert into larg player(no_player,level no) values 
(:new.no_player,:new.levels); 

end if; 

end if; 

end; 


بعد ذلك قم بادخال مايلي : 


insert into player values('1','talal','11/11/1973','123456','riyadh1',1); 


سوف إمرهام_ع۲ه] بعد ذلك اذهب وقما بالاستعلام في جدول م رهاملاحظ ان المدخلات تمت على جدول 
تجد انه اضاف رقم اللاعب هناك. 
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